Oracle提供的序号函数
Oracle提供的序号函数:
以emp表为例:
1: rownum 最简单的序号 但是在order by之前就确定值.
select rownum,t.* from emp t order by ename
行数 | ROWNUM | EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
1 | 11 | 7876 | ADAMS | CLERK | 7788 | 1987-5-23 | 1100 | 20 | |
2 | 2 | 7499 | ALLEN | SALESMAN | 7698 | 1981-2-20 | 1600 | 300 | 30 |
3 | 6 | 7698 | BLAKE | MANAGER | 7839 | 1981-5-1 | 2850 | 30 | |
4 | 7 | 7782 | CLARK | MANAGER | 7839 | 1981-6-9 | 2450 | 10 | |
5 | 13 | 7902 | FORD | ANALYST | 7566 | 1981-12-3 | 3000 | 20 | |
6 | 12 | 7900 | JAMES | CLERK | 7698 | 1981-12-3 | 950 | 30 | |
7 | 4 | 7566 | JONES | MANAGER | 7839 | 1981-4-2 | 2975 | 20 | |
8 | 9 | 7839 | KING | PRESIDENT | 1981-11-17 | 5000 | 10 | ||
9 | 5 | 7654 | MARTIN | SALESMAN | 7698 | 1981-9-28 | 1250 | 1400 | 30 |
10 | 14 | 7934 | MILLER | CLERK | 7782 | 1982-1-23 | 1300 | 10 | |
11 | 8 | 7788 | SCOTT | ANALYST | 7566 | 1987-4-19 | 3000 | 20 | |
12 | 1 | 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800 | 20 | |
13 | 10 | 7844 | TURNER | SALESMAN | 7698 | 1981-9-8 | 1500 | 0 | 30 |
14 | 3 | 7521 | WARD | SALESMAN | 7698 | 1981-2-22 | 1250 | 500 | 30 |
2: row_number() over( order by 字段名1,字段名2,...字段名n ) 先排序再确定序号.
select row_number() over( order by ename ) as rm, t.* from emp t
行数 | RM | EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
1 | 1 | 7876 | ADAMS | CLERK | 7788 | 1987-5-23 | 1100 | 20 | |
2 | 2 | 7499 | ALLEN | SALESMAN | 7698 | 1981-2-20 | 1600 | 300 | 30 |
3 | 3 | 7698 | BLAKE | MANAGER | 7839 | 1981-5-1 | 2850 | 30 | |
4 | 4 | 7782 | CLARK | MANAGER | 7839 | 1981-6-9 | 2450 | 10 | |
5 | 5 | 7902 | FORD | ANALYST | 7566 | 1981-12-3 | 3000 | 20 | |
6 | 6 | 7900 | JAMES | CLERK | 7698 | 1981-12-3 | 950 | 30 | |
7 | 7 | 7566 | JONES | MANAGER | 7839 | 1981-4-2 | 2975 | 20 | |
8 | 8 | 7839 | KING | PRESIDENT | 1981-11-17 | 5000 | 10 | ||
9 | 9 | 7654 | MARTIN | SALESMAN | 7698 | 1981-9-28 | 1250 | 1400 | 30 |
10 | 10 | 7934 | MILLER | CLERK | 7782 | 1982-1-23 | 1300 | 10 | |
11 | 11 | 7788 | SCOTT | ANALYST | 7566 | 1987-4-19 | 3000 | 20 | |
12 | 12 | 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800 | 20 | |
13 | 13 | 7844 | TURNER | SALESMAN | 7698 | 1981-9-8 | 1500 | 0 | 30 |
14 | 14 | 7521 | WARD | SALESMAN | 7698 | 1981-2-22 | 1250 | 500 | 30 |
3: 和上面的不同之处在于PARTITION分区.在每一个小分区内部取序号.
select row_number() over(PARTITION BY deptno order by sal ) as rm, t.* from emp t
行数 | RM | EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
1 | 1 | 7934 | MILLER | CLERK | 7782 | 1982-1-23 | 1300 | 10 | |
2 | 2 | 7782 | CLARK | MANAGER | 7839 | 1981-6-9 | 2450 | 10 | |
3 | 3 | 7839 | KING | PRESIDENT | 1981-11-17 | 5000 | 10 | ||
4 | 1 | 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800 | 20 | |
5 | 2 | 7876 | ADAMS | CLERK | 7788 | 1987-5-23 | 1100 | 20 | |
6 | 3 | 7566 | JONES | MANAGER | 7839 | 1981-4-2 | 2975 | 20 | |
7 | 4 | 7788 | SCOTT | ANALYST | 7566 | 1987-4-19 | 3000 | 20 | |
8 | 5 | 7902 | FORD | ANALYST | 7566 | 1981-12-3 | 3000 | 20 | |
9 | 1 | 7900 | JAMES | CLERK | 7698 | 1981-12-3 | 950 | 30 | |
10 | 2 | 7521 | WARD | SALESMAN | 7698 | 1981-2-22 | 1250 | 500 | 30 |
11 | 3 | 7654 | MARTIN | SALESMAN | 7698 | 1981-9-28 | 1250 | 1400 | 30 |
12 | 4 | 7844 | TURNER | SALESMAN | 7698 | 1981-9-8 | 1500 | 0 | 30 |
13 | 5 | 7499 | ALLEN | SALESMAN | 7698 | 1981-2-20 | 1600 | 300 | 30 |
14 | 6 | 7698 | BLAKE | MANAGER | 7839 | 1981-5-1 | 2850 | 30 |
4: rank()在这里表示针对每个部门员工的工资取序号.
select rank() over(PARTITION BY deptno order by sal ) as rnk, t.* from emp t;
行数 | RNK | EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
1 | 1 | 7934 | MILLER | CLERK | 7782 | 1982-1-23 | 1300 | 10 | |
2 | 2 | 7782 | CLARK | MANAGER | 7839 | 1981-6-9 | 2450 | 10 | |
3 | 3 | 7839 | KING | PRESIDENT | 1981-11-17 | 5000 | 10 | ||
4 | 1 | 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800 | 20 | |
5 | 2 | 7876 | ADAMS | CLERK | 7788 | 1987-5-23 | 1100 | 20 | |
6 | 3 | 7566 | JONES | MANAGER | 7839 | 1981-4-2 | 2975 | 20 | |
7 | 4 | 7788 | SCOTT | ANALYST | 7566 | 1987-4-19 | 3000 | 20 | |
8 | 4 | 7902 | FORD | ANALYST | 7566 | 1981-12-3 | 3000 | 20 | |
9 | 1 | 7900 | JAMES | CLERK | 7698 | 1981-12-3 | 950 | 30 | |
10 | 2 | 7521 | WARD | SALESMAN | 7698 | 1981-2-22 | 1250 | 500 | 30 |
11 | 2 | 7654 | MARTIN | SALESMAN | 7698 | 1981-9-28 | 1250 | 1400 | 30 |
12 | 4 | 7844 | TURNER | SALESMAN | 7698 | 1981-9-8 | 1500 | 0 | 30 |
13 | 5 | 7499 | ALLEN | SALESMAN | 7698 | 1981-2-20 | 1600 | 300 | 30 |
14 | 6 | 7698 | BLAKE | MANAGER | 7839 | 1981-5-1 | 2850 | 30 |
5: 从例子中可以看到dense_rank()和rank()的唯一区别就是:
dense_rank()中并列第二名后是第三名.
rank()中并列第二名后是第四名.
select dense_rank() over(PARTITION BY deptno order by sal ) as dense_rnk, t.* from emp t;
行数 | DENSE_RNK | EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
1 | 1 | 7934 | MILLER | CLERK | 7782 | 1982-1-23 | 1300 | 10 | |
2 | 2 | 7782 | CLARK | MANAGER | 7839 | 1981-6-9 | 2450 | 10 | |
3 | 3 | 7839 | KING | PRESIDENT | 1981-11-17 | 5000 | 10 | ||
4 | 1 | 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800 | 20 | |
5 | 2 | 7876 | ADAMS | CLERK | 7788 | 1987-5-23 | 1100 | 20 | |
6 | 3 | 7566 | JONES | MANAGER | 7839 | 1981-4-2 | 2975 | 20 | |
7 | 4 | 7788 | SCOTT | ANALYST | 7566 | 1987-4-19 | 3000 | 20 | |
8 | 4 | 7902 | FORD | ANALYST | 7566 | 1981-12-3 | 3000 | 20 | |
9 | 1 | 7900 | JAMES | CLERK | 7698 | 1981-12-3 | 950 | 30 | |
10 | 2 | 7521 | WARD | SALESMAN | 7698 | 1981-2-22 | 1250 | 500 | 30 |
11 | 2 | 7654 | MARTIN | SALESMAN | 7698 | 1981-9-28 | 1250 | 1400 | 30 |
12 | 3 | 7844 | TURNER | SALESMAN | 7698 | 1981-9-8 | 1500 | 0 | 30 |
13 | 4 | 7499 | ALLEN | SALESMAN | 7698 | 1981-2-20 | 1600 | 300 | 30 |
14 | 5 | 7698 | BLAKE | MANAGER | 7839 | 1981-5-1 | 2850 | 30 |
Oracle提供的序号函数相关推荐
- oracle提供的有用函数(待续)
DECODE函数 DECODE是Oracle公司独家提供的功能,它是一个功能很强的函数.它虽然不是SQL的 标准,但对于性能非常有用.到目前,其他的数据库供应商还不能提供类似DECODE的功能,甚至有 ...
- Oracle各类序号函数详解
Oracle提供的序号函数: 1.rownum rownum为最简单的序号 但是在order by之前就确定值. 举例: select rownum,--序号 year_name,--年份名称 mon ...
- Oracle索引梳理系列(六)- Oracle索引种类之函数索引
函数索引 1.1 概述 在实际应用中,当条件列使用函数运算进行数据匹配时,即使该列建立了索引,索引也不会被使用. 如下示例,其中在owner列上建立一个普通b-tree索引,观 察两种查询方式(不使用 ...
- 【Oracle】B-tree和函数索引
转自:https://www.cnblogs.com/yumiko/p/5957613.html 函数索引 1.1 概述 在实际应用中,当条件列使用函数运算进行数据匹配时,即使该列建立了索引,索引也不 ...
- Oracle报表计算合计函数ROLLUP
生成报表数据时,经常会加上一行合计,大多时候会用UNION ALL来实现,虽然也能达到目的,但是用UNION ALL往往效率会比较低,Oracle提供了计算合计的函数ROLLUP SELECT de ...
- oracle stdevp函数,SQL Server与oracle两者区别之函数区别
Oracle和SQL Server的常用函数对比 1.数学函数 ①绝对值 S:select abs(-1) value O:select abs(-1) value from dual ②取整(大) ...
- Oracle 中的一些函数
一.Oracle 比较大小函数 sign(n) 函数说明: 取数字 n 的符号,大于 0 返回 1:小于 0 返回 -1:等于 0 返回 0. 示例: 1.select sign( 2 ),sign( ...
- oracle sql时间排序函数,sql的rank函数
SQL SERVER 2008排序函数(窗口函数) 排序函数可以用来协助给结果集增加位置信息.SQL SERVER 2008只有四个排序函数,介绍如下: ROW_NUMBER:返回结果集中给定行的序号 ...
- Oracle NVL()和NVL2()函数
NVL函数的功能是实现空值的转换,根据第一个表达式的值是否为空值来返回响应的列名或表达式,主要用于对数据列上的空值进行处理,语法格式如:NVL( string1, replace_with),但此函数 ...
最新文章
- Java的JSON操作存储List到Redis
- python下拉菜单_python-web自动化:下拉列表操作
- C API向MySQL插入批量数据的快速方法——关于mysql_autocommit
- kernel 下串口serial输入输出控制,屏蔽log的输出
- Makefile总结
- mysql 4.0.21 下载_W2K下安装 MYSQL 4.0.21 手记
- [Qt入门]QTreeWidget控件创建
- 进程(并发,并行) join start 进程池 (同步异步)
- 解决MFC 窗口创建时 争夺焦点的问题
- native和html5的通信方案
- 福禄克DSX2-8000——支持铜缆、光纤、OTDR测试的多功能网线测试仪
- 如何将视频生成二维码
- 使用ARKit编码测量应用程序:对象和阴影
- 100句励志名句让你在困境中绝地求生
- u8反启用固定资产_U8和T3固定资产没有启用不能结账的处理方法
- ocpc php,研发相关 · 百度 oCPC 开发者文档
- laravel+容联.云通讯 实现手机短信验证用户注册
- 力扣解法汇总720-词典中最长的单词
- XXXXXXXX学校“新教师、新风采”展示课活动方案
- 求asinx+bcosx的不定积分