手机
当前位置:查字典教程网 >编程开发 >Java >Hibernate分页的两种实现方法
Hibernate分页的两种实现方法
摘要:本文实例讲述了Hibernate分页的两种实现方法。分享给大家供大家参考,具体如下:1.criteria分页publicPagegetPag...

本文实例讲述了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程序设计有所帮助。

【Hibernate分页的两种实现方法】相关文章:

Servlet与JSP间的两种传值情况

java对象转换String类型的三种方法

关于各种排列组合java算法实现方法

windows下java环境变量的设置方法

hibernate 命名查询如何实现

jfinal添加jcaptcha验证码实现方法

myeclipse智能提示设置的实现方法

使用java获取md5值的两种方法

java 二维数组矩阵乘法的实现方法

Java 获取指定日期的实现方法总结

精品推荐
分类导航