javaEE SSH三大框架整合,Spring整合Hibernate,HibernateTemplate实现增删改查,Dao层基类

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;
	}

}

猜你喜欢

转载自blog.csdn.net/houyanhua1/article/details/82188723