Hibernate分页的两种实现方法
更新时间:2016年03月24日 11:46:43 作者:ABCD
这篇文章主要介绍了Hibernate分页的两种实现方法,结合实例形式讲述了criteria分页与hql分页的实现方法,需要的朋友可以参考下
本文实例讲述了Hibernate分页的两种实现方法。分享给大家供大家参考,具体如下:
1. criteria分页
public Page getPage(int currentPage,int pageSize,Criterion...crts){ Criteria c=session.createCriteria(House.class); List list=null; for (int i = 0; i < crts.length; i++) { c.add(crts[i]); } c.setProjection(Projections.rowCount()); int totalRecord=Integer.valueOf(c.uniqueResult().toString()); c.setProjection(null); c.setFirstResult((pageSize)*(currentPage-1)); c.setMaxResults(pageSize); list=c.list(); Page page=new Page(); page.setCurrentPage(currentPage); page.setPageSize(pageSize); page.setTotalRecord(totalRecord); page.setList(list); return page; }
2. hql分页
public Page getPage(int currentPage,int pageSize,String hql,Object...args){ String countHql="select count(*) "+hql.substring(hql.indexOf("from")); Session session=HibernateUtil.getInstance().getSession(); Query query=session.createQuery(countHql); for (int i = 0; i < args.length; i++) { query.setParameter(i, args[i]); } int totalRecord=Integer.valueOf(query.uniqueResult()+""); query=session.createQuery(hql); for (int i = 0; i < args.length; i++) { query.setParameter(i, args[i]); } query.setFirstResult(pageSize*(currentPage-1)); query.setMaxResults(pageSize); List<House> list=(List<House>)query.list(); Page page=new Page(); page.setCurrentPage(currentPage); page.setPageSize(pageSize); page.setTotalRecord(totalRecord); page.setList(list); return page; }
希望本文所述对大家基于Hibernate框架的Java程序设计有所帮助。
相关文章
java连接池Druid获取连接getConnection示例详解
这篇文章主要为大家介绍了java连接池Druid获取连接getConnection示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-09-09IntelliJ IDEA 2020 安装和常用配置(推荐)
这篇文章主要介绍了IntelliJ IDEA 2020 安装和常用配置(推荐),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-08-08
最新评论