Hibernate使用

实现类:

public class InfoDAOImpl extends BaseDao<Info>

1、List<Object[]> midlist=super.createSqlQuery(sqlStr, null);//根据SQL返回记录,每条记录对应对象数组

2、Map map = new HashMap<>();//map和InfoDTO中属性相同

String querySQL="SELECT b.contract_no from ……";

map.put("contract_no", StringType.INSTANCE);

List<Object> param = new ArrayList<Object>();
   List<InfoDTO> list = super.createSqlQuery(querySQL, param, map, InfoForDTO.class);

均给予BaseDao

package com.common.dao;

import java.lang.reflect.ParameterizedType; import java.math.BigDecimal; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.Set;

import org.apache.log4j.Logger; import org.hibernate.HibernateException; import org.hibernate.Query; import org.hibernate.SQLQuery; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.criterion.CriteriaSpecification; import org.hibernate.transform.Transformers; import org.hibernate.type.Type; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.orm.hibernate4.HibernateCallback; import org.springframework.orm.hibernate4.support.HibernateDaoSupport; import org.springframework.stereotype.Component; import org.springframework.util.Assert;

import com.common.generic.page.PageResult;

@Component @SuppressWarnings("all") public class BaseDao<T> extends HibernateDaoSupport {    private static Integer BATCH_SIZE = 500;    private static Logger logger = Logger.getLogger(BaseDao.class);    private Class<T> clazz;

 public BaseDao() {   ParameterizedType pt = (ParameterizedType) this.getClass()     .getGenericSuperclass();   clazz = (Class<T>) pt.getActualTypeArguments()[0];  }

 @Autowired  public void setSuperSessionFactory(SessionFactory sessionFactory){   super.setSessionFactory(sessionFactory);  };    public SessionFactory getCurrentSessionFactory(){   return super.getSessionFactory();  };    public void clear() throws Exception{   getCurrentSessionFactory().getCurrentSession().clear();  }    public void merge(T entity) throws Exception{   getHibernateTemplate().merge(entity);  }   // public Session getSession(){ //  return getCurrentSessionFactory().openSession(); // }

 public void save(T entity) throws Exception{   getHibernateTemplate().save(entity);  }

 public void update(T entity) throws Exception{   getHibernateTemplate().update(entity);  }

 public void delete(T entity) throws Exception {   getHibernateTemplate().delete(entity);  }    public void delete(Long id) throws Exception{   T t = (T)this.getHibernateTemplate().get(clazz, id);   getHibernateTemplate().delete(t);  }    public void delete(String id) throws Exception{   T t = (T)this.getHibernateTemplate().get(clazz, id);   getHibernateTemplate().delete(t);  }    @SuppressWarnings("rawtypes")  public List<T> findAll() throws Exception{   List list = getHibernateTemplate().find(     "from " + clazz.getName());   return list;  }    @SuppressWarnings("rawtypes")  public List findAll(final String hql,final List<Object> value) throws Exception{   List list = getHibernateTemplate().execute(new HibernateCallback<List>() {

   public List doInHibernate(Session session)      throws HibernateException {     Query query = session.createQuery(hql);     if(value != null){      for (int i = 0; i < value.size(); i++) {       query.setParameter(i, value.get(i));      }     }     return query.list();    }   });   return list;  }    public T findById(Long id) throws Exception{   return (T) getHibernateTemplate().get(clazz, id);  }

 public T findById(String id) throws Exception{   return (T) getHibernateTemplate().get(clazz, id);  }    public Integer deleteByIdList(final Long[] idList) throws Exception{   final String hql = "delete from " + clazz.getName() + " where id in (:idList)";   int result = getHibernateTemplate().execute(new HibernateCallback<Integer>() {    public Integer doInHibernate(Session session) {     Query query = session.createQuery(hql)         .setParameterList("idList", idList);     return query.executeUpdate();    }   });   return result;  }    @SuppressWarnings("rawtypes")  public List<T> findByPage(final Integer beginIndex,final Integer pageSize) throws Exception{   List list = getHibernateTemplate().execute(new HibernateCallback<List>() {    public List doInHibernate(Session session){     //此方法查询后返回list结果     List result =session.createQuery("from " + clazz.getName()).setFirstResult(beginIndex)           .setMaxResults(pageSize).list();     return result;    }   });   return list;  }    @SuppressWarnings("rawtypes")  public List findByPage(final String hql,final List<Object> param,final int beginIndex,final int pageSize) throws Exception{   List list = getHibernateTemplate().execute(new HibernateCallback<List>() {    public List doInHibernate(Session session){     Query query = session.createQuery(hql);     if(param!=null){      for(int i =0;i<param.size();i++){       query.setParameter(i, param.get(i));      }     }     List result = query.setFirstResult(beginIndex).setMaxResults(pageSize).list();     return result;    }   });   return list;  }    /**   * 获取唯一结果   * @param hql HQL语句   * @param param HQL参数   * @return  Object对象   * @throws Exception   */  public Object findUniqueResult(final String hql,final List<Object> param) throws Exception{   Object obj =getHibernateTemplate().execute(new HibernateCallback<Object>() {    public Object doInHibernate(Session session){     Query query = session.createQuery(hql);     if(param!=null){      for(int i =0;i<param.size();i++){       query.setParameter(i, param.get(i));      }     }     return query.uniqueResult();    }   });   return obj;  }    /**   * 获取唯一结果   * @param sql  SQL语句   * @param param  SQL参数   * @return   Object对象   * @throws Exception   */  public Object findUniqueResultForSql(final String sql,final List<Object> param) throws Exception{   Object obj =getHibernateTemplate().execute(new HibernateCallback<Object>() {    public Object doInHibernate(Session session){     Query query = session.createSQLQuery(sql);     if(param!=null){      for(int i =0;i<param.size();i++){       query.setParameter(i, param.get(i));      }     }     return query.uniqueResult();    }   });   return obj;  }    /**   * 获取唯一的结果 结果类型为:Integer   * @param hql SQL语句   * @param param SQL参数   * @return  Integer   * @throws Exception   */  public Integer findUniqueNumberResultForSql(final String sql,final List<Object> param) throws Exception{   Object object = findUniqueResultForSql(sql,param);   return Integer.parseInt(object.toString());  }    /**   * 获取唯一的结果 结果类型为:Integer   * @param hql HQL语句   * @param param HQL参数   * @return  Integer   * @throws Exception   */  public Integer findUniqueNumberResult(final String hql,final List<Object> param) throws Exception{   Object object = findUniqueResult(hql,param);   return Integer.parseInt(object.toString());  }    /**   * SQL查询   * @param sql sql语句   * @param param sql参数   * @return  List集合   * @throws Exception   */  public List createSqlQuery(final String sql,final List<Object> param) throws Exception{   List list = getHibernateTemplate().execute(new HibernateCallback<List>() {    public List doInHibernate(Session session){     Query query = session.createSQLQuery(sql);     if(param!=null){      for(int i =0;i<param.size();i++){       query.setParameter(i, param.get(i));      }     }     List result = query.list();     return result;    }   });   return list;  }    /**   * SQL查询 会自动将结果封装成对象   * @param sql   sql   * @param param   参数   * @param scalar  类型   * @param classes  对象   * @return   * @throws Exception   */  public List createSqlQuery(final String sql,final List<Object> param,final Map<String,Type> scalar,final Class<?> classes) throws Exception{   List list = getHibernateTemplate().execute(new HibernateCallback<List>() {    public List doInHibernate(Session session){     SQLQuery query = session.createSQLQuery(sql);     if(param!=null){      for(int i =0;i<param.size();i++){       query.setParameter(i, param.get(i));      }     }     if(scalar != null && scalar.size() > 0){      Set<Map.Entry<String, Type>> scalarSet = scalar.entrySet();      Iterator<Map.Entry<String, Type>> iterator = scalarSet.iterator();      while(iterator.hasNext()){       Entry<String,Type> entry = iterator.next();       String columnName = entry.getKey();       Type type = entry.getValue();       query.addScalar(columnName, type);      }      query.setResultTransformer(Transformers.aliasToBean(classes));     }     List result = query.list();     return result;    }   });   return list;  }    /**   *   * <p>   * Description:SQL查询转化成对象<br />   * </p>   * @author haijun_liu   * @version 0.1 2015年10月23日   * @param sql   * @param param   * @param clas   * @return   * @throws Exception   * List   */  public List createSqlQuery(final String sql,final List<Object> param,final Class clas) throws Exception{   List list = getHibernateTemplate().execute(new HibernateCallback<List>() {    public List doInHibernate(Session session){     Query query = session.createSQLQuery(sql).addEntity(clas);     if(param!=null){      for(int i =0;i<param.size();i++){       query.setParameter(i, param.get(i));      }     }     List result = query.list();     return result;    }   });   return list;  }    /**   * 保存或更新对象   * @param entity 实体对象   */  public void saveOrUpdate(T entity){   getHibernateTemplate().saveOrUpdate(entity);  }    /**   * 批量保存   * @param list  list集合   * @throws Exception   */  public void batchSaveOrUpdate(final List<T> list) throws Exception{   getHibernateTemplate().execute(new HibernateCallback<Object>() {    public Object doInHibernate(Session session)      throws HibernateException {     logger.info(clazz.getCanonicalName() +"类批量添加开始....");     long startTime = System.currentTimeMillis();     if(list!= null && list.size() > 0){      for (int i = 0; i < list.size(); i++) {       T entity =list.get(i);       session.saveOrUpdate(entity);       if(i % BATCH_SIZE==0){        session.flush();        session.clear();       }      }      session.flush();      session.clear();     }     long endTime = System.currentTimeMillis();     logger.info(clazz.getCanonicalName() +"总耗时:"+(startTime-endTime)+"毫秒");     logger.info(clazz.getCanonicalName() +"类批量添加结束....");     return null;    }   });  }    public int executeUpdate(final String sql,final List<Object> param) throws Exception{   Integer count = getHibernateTemplate().execute(new HibernateCallback<Integer>() {    public Integer doInHibernate(Session session)      throws HibernateException {     Query query = session.createSQLQuery(sql);     if(param!=null){      for(int i =0;i<param.size();i++){       query.setParameter(i, param.get(i));      }     }     return query.executeUpdate();    }   });   return count;  }    public int batchExecuteUpdate(final List<String> sqlList,final List<Object[]> param) throws Exception{   Integer count = getHibernateTemplate().execute(new HibernateCallback<Integer>() {    public Integer doInHibernate(Session session)      throws HibernateException {     int updateCount =0;     for (int i = 0; i < sqlList.size(); i++) {      String sql =sqlList.get(i);      Query query = session.createSQLQuery(sql);      if(param!=null){       for(int j =0;j<param.size();j++){        Object[] params = param.get(i);        for (int k = 0; k < params.length; k++) {         query.setParameter(k, params[k]);        }       }      }      updateCount += query.executeUpdate();     }     return updateCount;    }   });   return count;  }    /*   * ------------------------ kun - start -----------------------   */    /**   * hql分页   * @param hql   * @param params 查询参数   * @param startIndex 数据偏移量,如第一页从0条记录形开始   * @param pageSize 每页条数   * @return   * @author Kun   * @date 2016年5月24日 下午4:00:45   */  public PageResult<T> pagedQuery(String hql, List<Object> params, int startIndex, int pageSize) {      // Count查询   String countQueryString = " select count(*) " + hql;   Long totalCount = (Long) createQuery(countQueryString, params).uniqueResult();

  if (totalCount < 1)    return new PageResult<T>();      // 实际查询返回分页对象 //  int startIndex = PageResult.getStartOfPage(pageNo, pageSize); // 改为直接从datatabels插件上取值   Query query = createQuery(hql, params);   List<T> list = query.setFirstResult(startIndex).setMaxResults(pageSize)     .list();

  return new PageResult<T>(totalCount.intValue(), list, 1, pageSize); // pageCurrent值暂时无用,当前页码由插件记录  }    /**   * sql分页   * @param sal   * @param startIndex 数据偏移量,如第一页从0条记录形开始   * @param pageSize 每页条数   * @param values 不定长查询参数   * @return   * @author Kun   * @date 2016年5月24日 下午4:00:45   */  public PageResult<Map> pageSqlQueryMap(String sql, int startIndex, int pageSize, Object... values) {      // Count查询   String countQueryString = " select count(*) from ("+sql+") t";   BigDecimal totalCount1 = (BigDecimal) createSqlQuerys(countQueryString, values).uniqueResult();   Integer totalCount=Integer.parseInt(totalCount1.toString());      if (totalCount < 1)    return new PageResult<Map>();      // 实际查询返回分页对象   SQLQuery query = createSqlQuerys(sql, values);   query.setResultTransformer(CriteriaSpecification.ALIAS_TO_ENTITY_MAP);   List<Map> list = query.setFirstResult(startIndex).setMaxResults(pageSize).list();      return new PageResult<Map>(totalCount, list, 1, pageSize);  }    /**   * 获取session   * @return   * @author Kun   * @date 2016年6月6日 下午2:04:30   */  protected Session getCurrentSession() {   return this.getCurrentSessionFactory().getCurrentSession();  }    /**   * 常规sql查询   * @param sql   * @param values 不定长查询参数   * @return   * @author Kun   * @date 2016年6月6日 下午2:04:53   */  protected SQLQuery createSqlQuerys(String sql, Object... values) {   Assert.hasText(sql);   SQLQuery query = getCurrentSession().createSQLQuery(sql);   //query.setCacheable(true);   for (int i = 0; i < values.length; i++) {    query.setParameter(i, values[i]);   }   return query;  }    /**   * 常规hql查询   * @param hql   * @param params   * @return   * @author Kun   * @date 2016年6月6日 下午2:05:10   */  protected Query createQuery(String hql, List<Object> params) {   Assert.hasText(hql);   Query query = getCurrentSession().createQuery(hql);   query.setCacheable(true);   if(params != null) {    for (int i = 0; i < params.size(); i++) {     query.setParameter(i, params.get(i));    }   }   return query;  }    /*   * ------------------------ kun - end -----------------------   */   }

原文地址:https://www.cnblogs.com/Defry/p/5667532.html