SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= 40
)
WHERE RN >= 21
其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN >= 21控制分页查询的每页的范围。
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE ROWNUM <= 40这句上。
选择第21到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。这是,查询语句如下:
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
)
WHERE RN BETWEEN 21 AND 40
对比这两种写法,绝大多数的情况下,第一个查询的效率比第二个高得多。
分享到:
相关推荐
select * from (select a.*,rownum rn from (select * from tablename) a where rownum) where rn>2
环境: Oracle 9i 本例子使用简单的SQL语句实现Oracle数据库的分页动作。它没有使用PL/SQL语句(比如什么程序包、游标等),只是使用通用的、简单的SQL实现了...分页公式注释非常详细,是非常实用的Oracle分页语句!!
Oracle的分页查询语句以及Oracle分页的存储过程
msql和oracle分页查询语句笔记
oracle分页查询语句sql
oracle 分页 很棒的实现方法,大家可以分析下。
Oracle分页查询语句的学习和示例演练
NULL 博文链接:https://yan578351314.iteye.com/blog/911307
高效多条件 Oracle 分页存储过程 ,快速分页
SQL Server 存储过程及Oracle SQL语句分页
一些常用到的在oracle中的sql语句,也是我在网上找到的,分享给大家
mysql和oracle的分页语句
网上搜集的oracle分页查询语句和性能分析
用ORACLE的SQL语句实现多栏分页输出.RTF
关于Oracle SQL语句分页问题:这里有一些实例,仅供大家下载来参考,如果有更好、更简便的方法,可以跟帖一起交流一下
之前一直用SQL SERVER做项目,但是现在需要用到ORACLE,在网上找了几个都无法正常调用,因此自己写了一个,给大家一起分享,在写的过程中学习到了很多东西,同时也体会到了SQL SERVER和ORACLE中的异同点 在分页存储...
这里只是总结了MySQL,SQL Server,Oracle分页语句。供大家参考
Oracle 分页和排序常用的4条查询语句
Java面试题28.mysql和oracle的分页语句(着重说思路).mp4
Oracle的分页查询语句