oracle复杂sql 分页,oracle sql 分页

Oracle实现分页时,需要引入一个rownum的函数,rownum可以给记录一个类似于id的字段。

以下收整理了常用的几种sql分页算法,数据库以Oracle中emp为例。查询结果如下:

SQL> select * from emp;

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO

----- ---------- --------- ----- ----------- --------- --------- ------

7369 SMITH      CLERK      7902 1980/12/17     800.00               20

7499 ALLEN      SALESMAN   7698 1981/2/20     1600.00    300.00     30

7521 WARD       SALESMAN   7698 1981/2/22     1250.00    500.00     30

7566 JONES      MANAGER    7839 1981/4/2      2975.00               20

7654 MARTIN     SALESMAN   7698 1981/9/28     1250.00   1400.00     30

7698 BLAKE      MANAGER    7839 1981/5/1      2850.00               30

7782 CLARK      MANAGER    7839 1981/6/9      2450.00               10

7788 SCOTT      ANALYST    7566 1987/4/19     3000.00               20

7839 KING       PRESIDENT       1981/11/17    5000.00               10

7844 TURNER     SALESMAN   7698 1981/9/8      1500.00      0.00     30

7876 ADAMS      CLERK      7788 1987/5/23     1100.00               20

7900 JAMES      CLERK      7698 1981/12/3      950.00               30

7902 FORD       ANALYST    7566 1981/12/3     3000.00               20

7934 MILLER     CLERK      7782 1982/1/23     1300.00               10

14 rows selected

分页方法1:使用嵌套查询

SQL> select * from ( select t1.* , rownum as n from emp t1 where rownum  <= 15 ) where n >= 10;

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO          N

----- ---------- --------- ----- ----------- --------- --------- ------ ----------

7844 TURNER     SALESMAN   7698 1981/9/8      1500.00      0.00     30         10

7876 ADAMS      CLERK      7788 1987/5/23     1100.00               20         11

7900 JAMES      CLERK      7698 1981/12/3      950.00               30         12

7902 FORD       ANALYST    7566 1981/12/3     3000.00               20         13

7934 MILLER     CLERK      7782 1982/1/23     1300.00               10         14

分页方法2:使用minus

SQL> select * from emp where rownum <= 14 minus select * from emp where rownum < 10;

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO

----- ---------- --------- ----- ----------- --------- --------- ------

7844 TURNER     SALESMAN   7698 1981/9/8      1500.00      0.00     30

7876 ADAMS      CLERK      7788 1987/5/23     1100.00               20

7900 JAMES      CLERK      7698 1981/12/3      950.00               30

7902 FORD       ANALYST    7566 1981/12/3     3000.00               20

7934 MILLER     CLERK      7782 1982/1/23     1300.00               10

在方法二中,如果minus后的查询语句执行where rownum > 10时,为什么不能查询到任何的记录呢?

ROWNUM是对结果集加的一个伪列,即先查到结果集之后再加上去的一个列(强调:先有结果集后再添加伪列)。

简单的说 rownum 是对符合条件结果的序列号。它总是从1开始排起的。不能对rownum用">"。它与rownum实现的机制是有关的。同时, 也无法使用rownum = n(n>1的自然数)。rownum都是从1开始。

分页方法3 : 使用rowid

SQL>

select * from emp where rowid in ( select rid from (select rowid as

rid, rownum as id from emp t where rownum < 15) where id >= 10 );

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO

----- ---------- --------- ----- ----------- --------- --------- ------

7876 ADAMS      CLERK      7788 1987/5/23     1100.00               20

7844 TURNER     SALESMAN   7698 1981/9/8      1500.00      0.00     30

7900 JAMES      CLERK      7698 1981/12/3      950.00               30

7902 FORD       ANALYST    7566 1981/12/3     3000.00               20

7934 MILLER     CLERK      7782 1982/1/23     1300.00               10

方法四:使用分析函数

SQL> select * from ( select t.* , row_number() over(order by ename) as num from emp t ) where num between 10 and 15;

EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO NUM

----- ---------- --------- ----- ----------- --------- --------- ------ ----------

7934 MILLER CLERK 7782 1982/1/23 1300.00 10 10

7788 SCOTT ANALYST 7566 1987/4/19 3000.00 20 11

7369 SMITH CLERK 7902 1980/12/17 800.00 20 12

7844 TURNER SALESMAN 7698 1981/9/8 1500.00 0.00 30 13

7521 WARD SALESMAN 7698 1981/2/22 1250.00 500.00 30 14

方法五:使用rownum伪列查询所有记录后,外层使用between and 或 大于 小于

SQL> select * from (select t.* , rownum as num from emp t) where num between 10 and 15;

EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO NUM

----- ---------- --------- ----- ----------- --------- --------- ------ ----------

7844 TURNER SALESMAN 7698 1981/9/8 1500.00 0.00 30 10

7876 ADAMS CLERK 7788 1987/5/23 1100.00 20 11

7900 JAMES CLERK 7698 1981/12/3 950.00 30 12

7902 FORD ANALYST 7566 1981/12/3 3000.00 20 13

7934 MILLER CLERK 7782 1982/1/23 1300.00 10 14

Oracle 的分页查询 SQL 语句

Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用. 分页查询格式: SELECT * FROM (SELECT A.*, ROWNUM RN FROM (SELECT * FROM T ...

Oracle中的SQL分页查询原理和方法详解

Oracle中的SQL分页查询原理和方法详解 分析得不错! http://blog.csdn.net/anxpp/article/details/51534006

对于Oracle中分页排序查询语句执行效率的比较分析

转自:http://bbs.csdn.net/topics/370033478 对于Oracle中分页排序查询语句执行效率的比较分析 作者:lzgame 在工作中我们经常遇到需要在Oracle中进行分 ...

oracle15 pl&sol;sql 分页

PL/SQL分页 编写分页过程 无返回值的存储过程 古人云:欲速则不达,为了让大家伙比较容易接受分页过程编写,我还是从简单到复杂,循序渐进的给大家讲解.首先是掌握最简单的存储过程,无返回值的存储过程: ...

Oracle的分页查询语句优化

Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用. (一)   分页查询格式: SELECT * FROM  ( SELECT A.*, ROWNUM RN  FROM (SELECT ...

oracle高效分页查询总结

本文参考链接:http://blog.sina.com.cn/s/blog_8604ca230100vro9.html 探索查询语句: --分页参数:size = 20 page = 2 --没有or ...

Oracle rownum 分页&comma; 排序

Oracle rownum 分页, 排序 什么是rownum, rownum的生成, rownum相关的符号操作 Rownum是oracle生成结果集时得到的一个伪列, 按照读出行的顺序, 第一条ro ...

Oracle高效分页查询(转)

page --没有order by的查询 -- 嵌套子查询,两次筛选(推荐使用) --SELECT * -- FROM (SELECT ROWNUM AS rowno, t.* -- FROM DON ...

SQL分页数据重复问题

对于关系数据库来说,直接写SQL拉数据在列表中显示是很常用的做法.但如此便带来一个问题:当数据量大到一定程度时,系统内存迟早会耗光.另外,网络传输也是问题.如果有1000万条数据,用户想看最后一条,这 ...

随机推荐

Redis&lowbar;密码管理&lpar;转&rpar;

一. 如何初始化redis的密码? 总共2个步骤: a.在配置文件中有个参数: requirepass  这个就是配置redis访问密码的参数. 比如 requirepass test123 b.配置 ...

集合框架遍历方式之——for-each循环

从Java5起,在Java中有了for-each循环,可以用来循环遍历collection和array.Foreach循环允许你在无需保持传统for循环中的索引,或在使用iterator /ListI ...

Unity协程&lpar;Coroutine&rpar;管理类——TaskManager工具分享

博客分类: Unity3D插件学习,工具分享 源码分析   Unity协程(Coroutine)管理类——TaskManager工具分享 By D.S.Qiu 尊重他人的劳动,支持原创,转载请注明出处 ...

shell编程-1到100的求和与冒泡排序

Shell编程 一.  for循环 生成列表 {起始数..结束数} 命令生成列表 `seq [起始数] [步进长度] 结束数 ` for  l in {1..5};do for  l in `seq ...

vc 制作图片资源dll

方法一: 使用纯WIN32 DLL方法封装纯资源第一步,通过VS2005建立WIN32 DLL 空工程第二步,设置配置属性->链接器->高级->无入口点(是/NOENTRY)设置配置 ...

php 中文转拼音首字母问题

JS批量替换内容中关键词为超链接,避开已存在的链接和alt、title中的关键词

懂点seo的人都知道要给内容中关键词加上链接,形成站内锚文本链接,这对seo有很大的帮助. 思路就是在数据库中录入若干个关键词和关键词对应的链接,当然链接可以根据关键词的id自动生成,或者直接用关键词 ...

Java面试常会被问到的经典面试题,学习或者求职,你都要好好掌握

Java现在的热度虽然有所下降,但是,学Java的人依旧很多..Java的岗位也是渗透很多.那么,那些经典的Java知识点,你能看到问题就能说出一二三吗?来一起看看.. 1.JDK和JRE的区别 2. ...

javase学习小结一

输出格式: int num=12345; System.out.printf("%7d",number);输出结果为:空格空格12345 System.out.println(&q ...

Go语言-通道类型

通道(Channel)是Go语言中一种非常独特的数据结构.它可用于在不同Goroutine之间传递类型化的数据,并且是并发安全的.相比之下,我们之前介绍的那些数据类型都不是并发安全的.这一点需要特别注 ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值