ORACLE SQL_分页查询

                      ORACLE SQL _分页查询

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

开发工具与关键技术:Oracle sql * plus  PLSQL Developer

作者:叶

撰写时间:2019年01月01日

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

  TOP-N 分析:

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

简单的说 ROWNUM 是对符合条件结果的序列号。

它是从1 开始排起的      

说明:ROWNUM “伪列”---数据表本身并没有这样的列,是ORACLE数据库为每个数据表

 “加上的”列。

例如:

          先用子查询查询出姓名,工资,按工资进行降序排序,子查询查出来的结果给到

     主查询查询 再用ROWNUM “伪列”进行重新排序,最后使用WHERE 条件语句筛选。

SELECT LAST_ANME, SALARY FROM (SELECT LAST_NAME, SALARY FROM EMPLOYEES ORDER BY SALARY DESC) WHERE ROWNUM <=10

                            ORACLE SQL_分页查询_第1张图片

 

注意: **对ORWNUM 只能使用 < 或<=, 而是用=,>,>= 都将不能返回任何数据。

SELECT * FROM (SELECT ROWNUM RN, EMPLOYEE_ID, SALARY FROM (SELECT EMPLOYEE_ID, SALARY, LAST_NAME FROM EMPLOYEES ORDER BY SALARY DESC) WHERE ROWNUM <=50)

WHERE RN >40

                   ORACLE SQL_分页查询_第2张图片

对Oralce 数据库中记录进行分页: 每页显示10条记录,查看第4页的数据。

 

SELECT EMPLOYEE_ID, LAST_NAME, SALARY FROM (SELECT ROWNUM RN, EMPLOYEE_ID, LAST_NAME, SALARY FROM EMPLOYEES) F

WHERE F.RN <=40 AND F.RN > 30;

                ORACLE SQL_分页查询_第3张图片

 

注意: **对 oracle 分 页 必须使用 ROWNUM“伪列”。

你可能感兴趣的:(ORACLE SQL_分页查询)