1. rownum是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数。
2. rownum不能以任何基表的名称作为前缀。
按scott.emp为例:
按工资排序,并且以rownum作为序号
是这样写吗?
SQL> select rownum,emp.empno,emp.sal from emp order by sal;
ROWNUM EMPNO SAL
---------- ---------- ----------
1 7369 800
12 7900 950
11 7876 1100
3 7521 1250
5 7654 1250
14 7934 1300
10 7844 1500
2 7499 1600
7 7782 2450
6 7698 2850
4 7566 2975
ROWNUM EMPNO SAL
---------- ---------- ----------
8 7788 3000
13 7902 3000
9 7839 5000
让您失望了,rownum还是按自己的顺序。
应该这样写:
SQL> select rownum,e.empno,e.sal from (select * from emp order by sal) e;
ROWNUM EMPNO SAL
---------- ---------- ----------
1 7369 800
2 7900 950
3 7876 1100
4 7521 1250
5 7654 1250
6 7934 1300
7 7844 1500
8 7499 1600
9 7782 2450
10 7698 2850
11 7566 2975
ROWNUM EMPNO SAL
---------- ---------- ----------
12 7788 3000
13 7902 3000
14 7839 5000
已选择14行。
那么还想分页呢?再加一层子循环:
select rn,empno,sal from
(select rownum rn,t.* from
(select * from emp order by sal,empno) t)
where rn between 2 and 7;
RN EMPNO SAL
---------- ---------- ----------
2 7900 950
3 7876 1100
4 7521 1250
5 7654 1250
6 7934 1300
7 7844 1500
已选择6行。
分享到:
相关推荐
Oracle 分页实例 带分页控件用法 Oracle 实现数据列表分页。
java实现oracle分页策略完整版,可当做参考类使用,有详细注释,适合初学者。
oracle分页存储过程,oracle分页存储过程
oracle分页查询语句sql
oracle分页查询并返回总记录数据的存储过程
ORACLE分页查询效率
完整的java+oracle 分页代码,供初学者使用
oracle分页,比较简单很好懂,能够清楚知道oracle分页机制
Oracle All 添加 修改 更新 Oracle分页 emp表 存储过程实现
本文将结合作者近日工作中,在ORACLE数据库分页查询时,遇到一个小问题,为大家讲解如何解决Oracle分页查询中排序与效率问题。
Oracle分页存储过程,里面包含C#调用代码实例;
oracle分页查询常用方法 提供三种方法
Oracle分页查询Oracle分页查询Oracle分页查询Oracle分页查询
spring+ibatis+oracle分页缓存源码
msql和oracle分页查询语句笔记
Oracle分页(limit方式的运用)Oracle分页(limit方式的运用)
Oracle分页详解
oracle&jsp简单实现分页,注意到Oracle包