Rus*_*kov 6 oracle pagination hibernate
关于如何正确执行分页的stackoverflow有很多问题,对于oracle,最流行的答案是这样的:
select * from (
select row_.*, rownum rownum_
from (select * from some_table) row_
where rownum <= N)
where rownum_ > M;
Run Code Online (Sandbox Code Playgroud)
我到处都看过这个查询,而Hibernate也会为分页生成它.对于大多数情况来说可能没问题,但它需要全表扫描并且在大量数据上显着减慢.
有一个提示,应该有助于选择前N行
/*+ FIRST_ROWS(5000) */
Run Code Online (Sandbox Code Playgroud)
但是在选择第二页并且似乎也使用全扫描时它没有帮助,至少那是"解释计划"对我说的.
为了解决这个问题,我目前正在实现自定义分页 - 读取表中所有行的id并将它们分割到范围上,以便分页查询看起来像这样:
select * from some_table where id between N and M;
Run Code Online (Sandbox Code Playgroud)
我希望找到这个问题的供应商解决方案,但到目前为止还没有成功.
所以,问题是 - 我是否重新发明轮子,或者在没有完全扫描的情况下真的没有办法在oracle上实现分页?
Upd:在Oracle 12c中,他们引入了一种新的分页语法:
OFFSET N ROWS FETCH NEXT M ROWS ONLY;
Run Code Online (Sandbox Code Playgroud)
我已经尝试过解释计划,它似乎只是一个别名
select * from (
select row_.*, rownum rownum_
from (select * from some_table) row_
where rownum <= N)
where rownum_ > M;
Run Code Online (Sandbox Code Playgroud)
UPD2:刚刚发现了一个类似的问题 - Oracle和Pagination 看起来我以前在搜索重复项时一直不专心.所以,很可能我的问题的答案是否定的,但是,从那以后可能会发生一些变化......
首先:全表扫描并不总是魔鬼。
另外,当您进行测试时,请尝试使用具有高分页值的大表
补充要点:
我例外的是,您喜欢在数据库中“存储”查询并逐页获取数据,直到下划线数据发生变化?
归档时间: |
|
查看次数: |
1060 次 |
最近记录: |