BaseDaoImpl.java(Dao层基类,HibernateTemplate实现增删改查):
package cn.xxx.dao.impl;
import java.io.Serializable;
import java.lang.reflect.ParameterizedType;
import java.util.List;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Projections;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport;
import cn.xxx.dao.BaseDao;
public class BaseDaoImpl<T> extends HibernateDaoSupport implements BaseDao<T> {
private Class clazz; //用于接收运行期的泛型类型
public BaseDaoImpl() {
//获得当前类型的带有泛型类型的父类 (运行期this其实是BaseDaoImpl的某个子类,ptClass其实就是BaseDaoImpl本身)
ParameterizedType ptClass = (ParameterizedType) this.getClass().getGenericSuperclass();
//获得运行期的泛型类型
clazz = (Class) ptClass.getActualTypeArguments()[0];
}
@Override
public void save(T t) {
// 添加
getHibernateTemplate().save(t);
}
@Override
public void delete(T t) {
// 删除
getHibernateTemplate().delete(t);
}
@Override
public void delete(Serializable id) {
T t = this.getById(id);//先取,再删
getHibernateTemplate().delete(t);
}
@Override
public void update(T t) {
// 修改
getHibernateTemplate().update(t);
}
@Override
//Serializable接口是八大基本类型以及String类型的父类
public T getById(Serializable id) {
// 根据id查询
return (T) getHibernateTemplate().get(clazz, id);
}
@Override
public Integer getTotalCount(DetachedCriteria dc) {
//设置查询的聚合函数(总记录数)
dc.setProjection(Projections.rowCount());
// 根据离线Criteria查询
List<Long> list = (List<Long>) getHibernateTemplate().findByCriteria(dc);
//清空设置的聚合函数,避免影响后续查询
dc.setProjection(null);
if(list!=null && list.size()>0){
Long count = list.get(0);
return count.intValue();
}else{
return null;
}
}
@Override
public List<T> getPageList(DetachedCriteria dc, Integer start, Integer pageSize) {
// 根据离线Criteria查询(start,pageSize用于分页)
List<T> list = (List<T>) getHibernateTemplate().findByCriteria(dc, start, pageSize);
return list;
}
}