Oracle分页
2015-07-28 12:04
363 查看
方法一:
其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN
>= 21控制分页查询的每页的范围。
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE
ROWNUM <= 40这句上。
选择第21到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE
ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。这是,查询语句如下:
方法二:
对比这两种写法,绝大多数的情况下,第一个查询的效率比第二个高得多。
这是由于CBO优化模式下,Oracle可以将外层的查询条件推到内层查询中,以提高内层查询的执行效率。对于第一个查询语句,第二层的查询条件WHERE
ROWNUM <= 40就可以被Oracle推入到内层查询中,这样Oracle查询的结果一旦超过了ROWNUM限制条件,就终止查询将结果返回了。
而第二个查询语句,由于查询条件BETWEEN 21 AND 40是存在于查询的第三层,而Oracle无法将第三层的查询条件推到最内层(即使推到最内层也没有意义,因为最内层查询不知道RN代表什么)。因此,对于第二个查询语句,Oracle最内层返回给中间层的是所有满足条件的数据,而中间层返回给最外层的也是所有数据。数据的过滤在最外层完成,显然这个效率要比第一个查询低得多。
上面分析的查询不仅仅是针对单表的简单查询,对于最内层查询是复杂的多表联合查询或最内层查询包含排序的情况一样有效。
<pre name="code" class="sql">SELECT * FROM (SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A WHERE ROWNUM <= 40) -- 40 = currentPage * pageSize WHERE RN >= 21 -- 21 = (currentPage-1) * pageSize
其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN
>= 21控制分页查询的每页的范围。
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE
ROWNUM <= 40这句上。
选择第21到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE
ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。这是,查询语句如下:
方法二:
<pre name="code" class="sql">SELECT * FROM (SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A) WHERE RN BETWEEN 21 AND 40
对比这两种写法,绝大多数的情况下,第一个查询的效率比第二个高得多。
这是由于CBO优化模式下,Oracle可以将外层的查询条件推到内层查询中,以提高内层查询的执行效率。对于第一个查询语句,第二层的查询条件WHERE
ROWNUM <= 40就可以被Oracle推入到内层查询中,这样Oracle查询的结果一旦超过了ROWNUM限制条件,就终止查询将结果返回了。
而第二个查询语句,由于查询条件BETWEEN 21 AND 40是存在于查询的第三层,而Oracle无法将第三层的查询条件推到最内层(即使推到最内层也没有意义,因为最内层查询不知道RN代表什么)。因此,对于第二个查询语句,Oracle最内层返回给中间层的是所有满足条件的数据,而中间层返回给最外层的也是所有数据。数据的过滤在最外层完成,显然这个效率要比第一个查询低得多。
上面分析的查询不仅仅是针对单表的简单查询,对于最内层查询是复杂的多表联合查询或最内层查询包含排序的情况一样有效。
相关文章推荐
- 新手学oracle常见疑问
- Oracle11g字符集AL32UTF8修改为ZHS16GBK详解
- oracle把表数据放入内存
- 两种oracle创建字段自增长的实现方式
- 实现oracle数据库字段自增长(两种方式)
- oracle11g,安装失败,提示找不到文件,win7 64位下报错
- oracle Net Manager 服务命名无法配置(无法新建、添加服务名)
- ORACLE大表中删除部分数据最佳方案
- oracle imp/exp 导出以及导出空表解决方法
- oracle数据库备份与还原
- oracle 10g正则表达式REGEXP_LIKE用法
- ERP云端争霸 甲骨文和SAP打对攻 金蝶忙转身用友原地等待
- SAP、ORACLE、用友、金蝶四大ERP软件供应商的区别
- 使用oracle中内置函数dbms_lob.instr()查询clob类型的字符串
- 批处理打开和关闭oracle11g 服务
- Oracle 递归函数与等级
- oracle rac 在完成安装错误。
- Oracle 9i 查看执行计划报错 ORA-02402: PLAN_TABLE not found
- 【CIO说】转型SaaS,为什么Oracle、SAP的第一选择是人力资源软件
- oracle使用@实例名报错