SSH框架:抽取dao层公共接口和父类

因为dao层功能比较固定大部分是在增删改查,所以可以抽取父类被继承,以此简化代码。因为是面向接口编程,所以我们新建一个接口文件BaseDao.java和一个实现类BaseDaoImpl.java,重点讲实现类怎么写

BaseDaoImpl.java

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

    // 定义成员的属性
    private Class clazz;

    public BaseDaoImpl(){
        // this表示的子类,c表示就是CustomerDaoImpl的Class对象
        Class c = this.getClass();
        // CustomerDaoImpl extends BaseDaoImpl  map
        // 第2步:获取到是BaseDaoImpl
        Type type = c.getGenericSuperclass();

        // 目的:把type接口转换成子接口
        if(type instanceof ParameterizedType){
            ParameterizedType ptype = (ParameterizedType) type;

            // 获取到 Customer
            Type[] types = ptype.getActualTypeArguments();
            this.clazz = (Class) types[0];
        }
    }

    /**
     * 添加
     */
    public void save(T t) {
        this.getHibernateTemplate().save(t);
    }

    /**
     * 删除
     */
    public void delete(T t) {
        this.getHibernateTemplate().delete(t);
    }

    /**
     * 修改
     */
    public void update(T t) {
        this.getHibernateTemplate().update(t);
    }

    /**
     * 通过主键查询
     */
    public T findById(Long id) {
        return (T) this.getHibernateTemplate().get(clazz, id);
    }

    /**
     * 查询所有的数据
     */
    public List findAll() {
        return (List) this.getHibernateTemplate().find("from "+clazz.getSimpleName());
    }

    /**
     * 分页查询
     */
    public PageBean findByPage(Integer pageCode, Integer pageSize, DetachedCriteria criteria) {
        // 创建分页的对象
        PageBean page = new PageBean();
        // 一个一个设置
        page.setPageCode(pageCode);
        page.setPageSize(pageSize);

        // 设置查询聚合函数:SQL已经变成了 select count(*) from 
        criteria.setProjection(Projections.rowCount());
        List list = (List) this.getHibernateTemplate().findByCriteria(criteria);
        if(list != null && list.size() > 0){
            int totalCount = list.get(0).intValue();
            // 总记录数
            page.setTotalCount(totalCount);
        }

        // 清除SQL select * from xxx
        criteria.setProjection(null);

        List beanList = (List) this.getHibernateTemplate().findByCriteria(criteria, (pageCode-1)*pageSize, pageSize);
        // 每页显示的数据
        page.setBeanList(beanList);
        return page;
    }
}

分页查询PageBean插件
http://blog.csdn.net/mozha_666/article/details/79301334

你可能感兴趣的:(SSH框架)