给结果集分页

为了便于查询网页中的数据,常常要分页显示。如:要求员工表按工资排序后一次只显示5行数据,下次再显示接下来的5行,以下以第二页数据(6到10行)为例进行分页。

SQL代码如下:

SELECT rn, ename, sal
  FROM (SELECT ROWNUM AS rn, ename, sal
          FROM (SELECT ename, sal FROM emp WHERE sal IS NOT NULL ORDER BY sal)
         WHERE ROWNUM <= 10)
 WHERE rn >= 6;

以上的SQL需要嵌套两次,你也可以先用row_number()生成序号,再过滤,这样就只需要嵌套一次。

SELECT rn, ename, sal
  FROM (SELECT ROW_NUMBER() OVER(ORDER BY sal) AS rn, ename, sal
          FROM emp
         WHERE sal IS NOT NULL)
 WHERE rn BETWEEN 6 AND 10;

这个语句比较简单,但因为分页语句的特殊性,在调用PLAN时可能会受到分析函数的影响,有些索引或PLAN(如:first_rows)不能用。所以建议使用第一种分页方式,把第一种分页方式当作模版,然后套用。

posted on 2015-10-25 21:02  奈何作贼  阅读(440)  评论(0编辑  收藏  举报

导航