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
注意: **对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
对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 分 页 必须使用 ROWNUM“伪列”。