度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1005|回复: 4
打印 上一主题 下一主题

[分享] oracle 分页查询小结

[复制链接]

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
跳转到指定楼层
楼主
发表于 2020-5-4 16:00:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
分页查询的目的就是控制输出结果集大小,将结果尽快的返回

--在查询的第二层通过ROWNUM <= ??? 来控制最大值,在查询的最外层控制最小值
select * from (select a.*,rownum rn from (select * from sa_staff_info) a where rownum <=2800) where rn >=2780;

--在查询的最外层控制分页的最小值和最大值
select * from (select a.*,rownum rn from (select * from sa_staff_info) a ) where rn between 2780 and 2800;

通过对两条sql语句的测试运行,发现第二条sql运行时间大约要比第一条sql运行时间多0.002秒
这是由于CBO优化模式下,Oracle可以将外层的查询条件推到内层查询中,以提高内层查询的执行效率。对于第一个查询语句,第二层的查询条件WHERE ROWNUM <= 40就可以被Oracle推入到内层查询中,这样Oracle查询的结果一旦超过了ROWNUM限制条件,就终止查询将结果返回了

--用rownum来分页,并排序
select * from (select a.*,rownum rn from (select * from sa_staff_info order by login_name) a where rownum <=20) where rn >=11;
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

348

主题

3572

帖子

9300

积分

论坛元老

Rank: 8Rank: 8

积分
9300
沙发
发表于 2020-5-6 22:46:41 | 只看该作者
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复 支持 反对

使用道具 举报

348

主题

3572

帖子

9300

积分

论坛元老

Rank: 8Rank: 8

积分
9300
板凳
发表于 2020-5-6 22:54:53 | 只看该作者
练习,练习
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复 支持 反对

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
地板
 楼主| 发表于 2020-5-7 16:47:24 | 只看该作者
回复 支持 反对

使用道具 举报

198

主题

1313

帖子

3782

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
3782
5#
发表于 2020-5-7 16:48:27 | 只看该作者
这个学的如何了,要好好的使用哟。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-11-1 23:36 , Processed in 0.157205 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表