BaseDao设计示例

本文基于搭建的ssh框架

Dao层有许多重复的简单的增删改查,可以抽取出来,减少冗余代码。分享一下自己的实现案例。有许多深度好文,这里直接上代码。

只是抽取了出来,别的都不用改。

Dao层:

package cn.itcast.dao;

import java.io.Serializable;
import java.util.List;

import org.hibernate.criterion.DetachedCriteria;

public interface BaseDao<T> {
    //未知类型,声明泛型变量T
    //
    void save(T t);
    //
    void delete(T t);
    //删 涉及类型id,实现Serializable,序列化。基础类型也是实现Serializable
    void delete(Serializable id);
    //
    void update(T t);
    //查 根据id查询
    T getById(Serializable id);
    //查 符合条件的总记录数
    Integer getTotalCount(DetachedCriteria dc);
    //查 查询分页列表数据
    List<T> getPageList(DetachedCriteria dc,Integer start,Integer pageSize);
    
}

Dao.Impl

package cn.itcast.dao.impl;

import java.io.Serializable;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.List;

import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Projections;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport;

import cn.itcast.dao.BaseDao;
import cn.itcast.domain.Customer;

public class BaseDaoImpl<T> extends HibernateDaoSupport implements BaseDao<T> {

    private Class clszz;//用于接收运行期泛型类型
    
    public BaseDaoImpl(){
        // 获得当前类型的带有泛型类型的父类
        ParameterizedType ptClass = (ParameterizedType) this.getClass().getGenericSuperclass();
        // 获得运行期的泛型类型
        clszz = (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
    public T getById(Serializable id) {
        
        return (T) getHibernateTemplate().get(clszz, id);
    }

    @Override
    public Integer getTotalCount(DetachedCriteria dc) {
        // 设置聚合函数,查询总记录数
        dc.setProjection(Projections.rowCount());
        
        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) {
        // 查询记录list
        List<T> list = (List<T>) getHibernateTemplate().findByCriteria(dc, start, pageSize);
        return list;
    }

}

以上就是抽取出来的接口与实现类。下面写一个用户需求实例。

package cn.itcast.dao;

import cn.itcast.domain.Customer;

public interface CustomerDao extends BaseDao<Customer> {
    // 查询总记录数
    // 查询分页列表数据list
}
package cn.itcast.dao.impl;

import cn.itcast.dao.CustomerDao;
import cn.itcast.domain.Customer;

public class CustomerDaoImpl extends BaseDaoImpl<Customer> implements CustomerDao {

}

没错,就是空的,没抽取之前是要写查询记录和查询分页数据。

posted @ 2020-03-27 21:06  黎明的太阳  Views(230)  Comments(0Edit  收藏  举报