关于分页写法的性能分析及ROWNUM的补充说明
1、分页写法一
SELECT *
FROM (SELECT ROWNUM RN, A.*
FROM (SELECT * FROM BPM_PROCVAR ORDER BY VARID) A
WHERE ROWNUM <= 40) B
WHERE B.RN >= 21;
查询结果:20条记录
查询时间:0.031秒
2、分页写法二
SELECT *
FROM (SELECT ROWNUM RN, A.*
FROM (SELECT * FROM BPM_PROCVAR ORDER BY VARID) A) B
WHERE B.RN >= 21
AND B.RN <= 40;
查询结果:20条记录
执行时间:13.224秒
3、分页写法三
SELECT ROWNUM RN1, ROWNUM RN2, A.*
FROM (SELECT * FROM BPM_PROCVAR ORDER BY VARID) A
WHERE ROWNUM <= 40
AND ROWNUM >= 21;
查询结果:0条记录
执行时间:1.622秒
分页写法一分析:CBO优化模式下,Oracle可以将外层的查询条件推到内层查询中,以提高内层查询的执行效率。对于第一个查询语句,第二层的查询条件WHERE ROWNUM <= 40就可以被Oracle推入到内层查询中,这样Oracle查询的结果一旦超过了ROWNUM限制条件,就终止查询将结果返回了。
分页写法三分析:rownum 是对符合条件结果的序列号。它总是从1开始排起的。所以你选出的结果不可能没有1,而有其他大于1的值。