ROW_NUMBER() OVER()
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,ROW_NUMBER()OVER() 是Oracle SQL分析函数,主要是用来对要查询的数据分组排序使用。使用方法ROW_NUMBER()OVER(PARTITION BY col1 ORDER B
千家信息网最后更新 2025年01月20日ROW_NUMBER() OVER()
ROW_NUMBER()OVER() 是Oracle SQL分析函数,主要是用来对要查询的数据分组排序使用。
使用方法
ROW_NUMBER()OVER(PARTITION BY col1 ORDER BY col2)
对列col1分组,col2排序操作。
例子:
SQL> SELECT 2 ROW_NUMBER()OVER(PARTITION BY deptno ORDER BY sal, empno) AS rn, 3 empno, ename, sal, deptno 4 FROM emp; RN EMPNO ENAME SAL DEPTNO---------- ---------- ---------- ---------- ---------- 1 7934 MILLER 1300 10 2 7782 CLARK 2450 10 3 7839 KING 5000 10 1 7369 SMITH 800 20 2 7876 ADAMS 1100 20 3 7566 JONES 2975 20 4 7788 SCOTT 3000 20 5 7902 FORD 3000 20 1 7900 JAMES 950 30 2 7521 WARD 1250 30 3 7654 MARTIN 1250 30 RN EMPNO ENAME SAL DEPTNO---------- ---------- ---------- ---------- ---------- 4 7844 TURNER 1500 30 5 7499 ALLEN 1600 30 6 7698 BLAKE 2850 3014 rows selected.
同时也可以单独使用其来对结果进行排序
可以和order by 对比一下:
SQL> SELECT empno, ename, sal, 2 ROW_NUMBER()OVER(ORDER BY sal, empno) AS rn 3 FROM emp; EMPNO ENAME SAL RN---------- ---------- ---------- ---------- 7369 SMITH 800 1 7900 JAMES 950 2 7876 ADAMS 1100 3 7521 WARD 1250 4 7654 MARTIN 1250 5 7934 MILLER 1300 6 7844 TURNER 1500 7 7499 ALLEN 1600 8 7782 CLARK 2450 9 7698 BLAKE 2850 10 7566 JONES 2975 11 EMPNO ENAME SAL RN---------- ---------- ---------- ---------- 7788 SCOTT 3000 12 7902 FORD 3000 13 7839 KING 5000 1414 rows selected.Execution Plan----------------------------------------------------------Plan hash value: 3145491563---------------------------------------------------------------------------| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |---------------------------------------------------------------------------| 0 | SELECT STATEMENT | | 14 | 462 | 4 (25)| 00:00:01 || 1 | WINDOW SORT | | 14 | 462 | 4 (25)| 00:00:01 || 2 | TABLE ACCESS FULL| EMP | 14 | 462 | 3 (0)| 00:00:01 |---------------------------------------------------------------------------Note----- - dynamic sampling used for this statement (level=2)Statistics---------------------------------------------------------- 5 recursive calls 0 db block gets 16 consistent gets 1 physical reads 0 redo size 1049 bytes sent via SQL*Net to client 523 bytes received via SQL*Net from client 2 SQL*Net roundtrips to/from client 1 sorts (memory) 0 sorts (disk) 14 rows processedSQL> SELECT empno, ename, sal 2 FROM emp 3 ORDER BY sal, empno; EMPNO ENAME SAL---------- ---------- ---------- 7369 SMITH 800 7900 JAMES 950 7876 ADAMS 1100 7521 WARD 1250 7654 MARTIN 1250 7934 MILLER 1300 7844 TURNER 1500 7499 ALLEN 1600 7782 CLARK 2450 7698 BLAKE 2850 7566 JONES 2975 EMPNO ENAME SAL---------- ---------- ---------- 7788 SCOTT 3000 7902 FORD 3000 7839 KING 500014 rows selected.Execution Plan----------------------------------------------------------Plan hash value: 150391907---------------------------------------------------------------------------| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |---------------------------------------------------------------------------| 0 | SELECT STATEMENT | | 14 | 462 | 4 (25)| 00:00:01 || 1 | SORT ORDER BY | | 14 | 462 | 4 (25)| 00:00:01 || 2 | TABLE ACCESS FULL| EMP | 14 | 462 | 3 (0)| 00:00:01 |---------------------------------------------------------------------------Note----- - dynamic sampling used for this statement (level=2)Statistics---------------------------------------------------------- 4 recursive calls 0 db block gets 16 consistent gets 1 physical reads 0 redo size 943 bytes sent via SQL*Net to client 523 bytes received via SQL*Net from client 2 SQL*Net roundtrips to/from client 1 sorts (memory) 0 sorts (disk) 14 rows processed
对比ORDER BY 子句,排序结果一样,使用ROW_NUMBER()OVER()函数可生产RN列,便于在某些列表程序选择行数。
排序
函数
结果
分组
使用方法
例子
可生产
同时
子句
数据
方法
程序
其来
可生
分析
查询
选择
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全销售难点在哪
网络安全系列征文
选煤工艺数据库
无线网络安全类型为wpa
网易我的世界服务器怎么弄平原
服务器名和计算机名一样吗
国产服务器处理器排行
软件开发项目验收人员的组成
中国科技软件开发行业数据
星澜直播软件开发
大连网络技术研究院
dw 代码连接数据库连接
北京平谷区网络技术培训
网络技术过硬的人员去哪找
怎样查看服务器的端口开放
如何安装dns服务器
甲骨文公司出的数据库软件
软件开发过程的三种模型
公司网络安全承诺书范文
还原苹果手机连接服务器出现问题
东营企业管理软件开发
江苏智能边缘计算服务器
数据库默认使用快照吗
我的世界服务器里的英文
国内ntp时间服务器ip
网络技术服务标准费用
网络安全靠人民的小报怎么画
软件开发人员年龄年薪信息
松果数据库
在发生网络安全事件