首页 > 其他 > 详细

给结果集分页

时间:2015-10-25 22:07:46      阅读:204      评论:0      收藏:0      [点我收藏+]

为了便于查询网页中的数据,常常要分页显示。如:要求员工表按工资排序后一次只显示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)不能用。所以建议使用第一种分页方式,把第一种分页方式当作模版,然后套用。

给结果集分页

原文:http://www.cnblogs.com/minisculestep/p/4909581.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!