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<Customer>  map<k,v>
        // 第2步:获取到是BaseDaoImpl<Customer>
        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<T> findAll() {
        return (List<T>) this.getHibernateTemplate().find("from "+clazz.getSimpleName());
    }

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

        // 设置查询聚合函数:SQL已经变成了 select count(*) from 
        criteria.setProjection(Projections.rowCount());
        List<Number> list = (List<Number>) 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<T> beanList = (List<T>) this.getHibernateTemplate().findByCriteria(criteria, (pageCode-1)*pageSize, pageSize);
        // 每页显示的数据
        page.setBeanList(beanList);
        return page;
    }
}

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值