Hibernate分页的两种方式

/**   
 * @Title: 类名:BaseDaoSupport
 * @Description: 文件描述
 * @author wh   
 * @date 2012-2-23 18:48:18
 * @version V1.0   
 */
public class BaseDaoSupport extends HibernateDaoSupport {


    public PageModel setPageQuery(final StringBuilder hql, final Integer begin, final Integer end, final String orderField, final String srot, final boolean isPage) {
        StringBuilder countHql = new StringBuilder("select count(id) ").append(hql.toString());


        if (!CommUtils.isNull(orderField)) {
            //排序字段
            hql.append(" order by ").append(orderField);
            if (!CommUtils.isNull(srot)) {
                hql.append(" ").append(srot);
            }
        }
        HibernateTemplate template = this.getHibernateTemplate();
        //开启查询缓存
//        template.setCacheQueries(SystemConstants.isUseCacheQuery);
        List list = template.executeFind(new HibernateCallback() {


            @Override
            public List doInHibernate(Session session)
                    throws HibernateException, SQLException {
                Query query = session.createQuery(hql.toString());
                if (!CommUtils.isNull(begin)) {
                    query.setFirstResult(begin);
                }
                if (!CommUtils.isNull(end)) {
                    query.setMaxResults(end);
                }
                return query.list();
            }
        });
        PageModel page = new PageModel();
        if (!CommUtils.isNull(list)) {
            if (isPage) {
                Long totalCount = (Long) template.find(countHql.toString()).iterator().next();
                page.setTotalCount(totalCount);
            } else {
                page.setTotalCount(list.size());
            }
            page.setResult(list);
        }
        return page;
    }


    /**
     * Criteria模式分页
     * @param begin:起始页
     * @param end:最大也
     * @param orderField:排序字段
     * @param srot:排序方式
     * @param isPage:是否分页数据
     * @return 
     */
    public PageModel setCriteriaPageQuery(final Criteria criteria, final Integer beginPage, final Integer maxPage, final String orderField, final String sort, final boolean isPage) {


        if (!CommUtils.isNull(orderField) && !CommUtils.isNull(sort)) {
            criteria.addOrder(Order.asc(sort));
        }
        HibernateTemplate template = this.getHibernateTemplate();
        //开启查询缓存
//        template.setCacheQueries(SystemConstants.isUseCacheQuery);
        List list = template.executeFind(new HibernateCallback() {


            @Override
            public List doInHibernate(Session session)
                    throws HibernateException, SQLException {
                if (!CommUtils.isNull(beginPage)) {
                    criteria.setFirstResult(beginPage);
                }
                if (!CommUtils.isNull(maxPage)) {
                    criteria.setMaxResults(maxPage);
                }
                return criteria.list();
            }
        });
        PageModel page = new PageModel();
        if (!CommUtils.isNull(list)) {
            if (isPage) {
                //清空聚合对象
                criteria.setProjection(null);
                //获取总行数
                long totalCount = (Integer) criteria.setProjection(Projections.rowCount()).uniqueResult();
                page.setTotalCount(totalCount);
            } else {
                page.setTotalCount(list.size());
            }
            page.setResult(list);
        }
        return page;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值