基于Hibernate分页原理的Oracle专用高效万能分页控件

本文介绍了Hibernate实现分页查询的方法,如从第2万条开始取100条记录的示例。还探讨了Hibernate底层分页实现,若数据库定义了限定查询记录的sql语句,会直接使用。以Oracle为例,采用嵌套3层查询结合rownum实现分页,后续打算整合不同数据库分页代码。


打字麻烦。大家看flash吧。

Hibernate 可以实现分页查询,例如:

从第2万条开始取出100条记录

Query q = session.createQuery("from Cat as c");
q.setFirstResult(20000);
q.setMaxResults(100);
List l = q.list();

那么Hibernate底层如何实现分页的呢?实际上Hibernate的查询定义在net.sf.hibernate.loader.Loader这个类里面,仔细阅读该类代码,就可以把问题彻底搞清楚。

Hibernate2.0.3的Loader源代码第480行以下:

if (useLimit) sql = dialect.getLimitString(sql);       
PreparedStatement st = session.getBatcher().prepareQueryStatement(sql, scrollable);

如果相应的数据库定义了限定查询记录的sql语句,那么直接使用特定数据库的sql语句。
public String getLimitString(String sql) {
  StringBuffer pagingSelect = new StringBuffer(100);
  pagingSelect.append("select * from ( select row_.*, rownum rownum_ from ( ");
  pagingSelect.append(sql);
  pagingSelect.append(" ) row_ where rownum <= ?) where rownum_ > ?");
  return pagingSelect.toString();
}

Oracle采用嵌套3层的查询语句结合rownum来实现分页,这在Oracle上是最快的方式,如果只是一层或者两层的查询语句的rownum不能支持order by。

下载flash
http://218.75.77.154/zfj/word/TzhPager.swf

下载控件自已玩玩。(请不要用于商业开发,本版本目前仅限技术研究)
http://218.75.77.154/zfj/word/TzhPager.dll
年后,把控件的代码再理一理。打算把sql server ,access的分页也都整合到一起,因为目前我都是分开写的。每个也就1000来行代码,应该可以合到一块。
到时看大家的回贴热情了。该共享就共享,该开源就开源。大过年的,还在写技术贴,无聊呀。

转载于:https://www.cnblogs.com/tongzhenhua/archive/2005/02/10/103685.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值