Hibernate分页的两种实现方法
本文实例讲述了Hibernate分页的两种实现方法。分享给大家供大家参考,具体如下:
1.criteria分页
publicPagegetPage(intcurrentPage,intpageSize,Criterion...crts){
Criteriac=session.createCriteria(House.class);
Listlist=null;
for(inti=0;i<crts.length;i++){
c.add(crts[i]);
}
c.setProjection(Projections.rowCount());
inttotalRecord=Integer.valueOf(c.uniqueResult().toString());
c.setProjection(null);
c.setFirstResult((pageSize)*(currentPage-1));
c.setMaxResults(pageSize);
list=c.list();
Pagepage=newPage();
page.setCurrentPage(currentPage);
page.setPageSize(pageSize);
page.setTotalRecord(totalRecord);
page.setList(list);
returnpage;
}
2.hql分页
publicPagegetPage(intcurrentPage,intpageSize,Stringhql,Object...args){
StringcountHql="selectcount(*)"+hql.substring(hql.indexOf("from"));
Sessionsession=HibernateUtil.getInstance().getSession();
Queryquery=session.createQuery(countHql);
for(inti=0;i<args.length;i++){
query.setParameter(i,args[i]);
}
inttotalRecord=Integer.valueOf(query.uniqueResult()+"");
query=session.createQuery(hql);
for(inti=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();
Pagepage=newPage();
page.setCurrentPage(currentPage);
page.setPageSize(pageSize);
page.setTotalRecord(totalRecord);
page.setList(list);
returnpage;
}
希望本文所述对大家基于Hibernate框架的Java程序设计有所帮助。
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短