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 序号函数的更多相关文章
- MSSQL和Oracle常用函数比对
数学函数 序号 函数功能 SQL Server用法 Oracle用法 1 绝对值 select abs(-1) value select abs(-1) value from dual 2 取整(大) ...
- Oracle分析函数——函数列表
--------------聚合函数 SUM :该函数计算组中表达式的累积和 MIN :在一个组中的数据窗口中查找表达式的最小值 MAX :在一个组中的数据窗口中查找表达式的最大值 AVG :用于计算 ...
- oracle add_months函数
oracle add_months函数 add_months 函数主要是对日期函数进行操作,举例子进行说明 add_months 有两个参数,第一个参数是日期,第二个参数是对日期进行加减的数字(以月为 ...
- Oracle to_date()函数的用法
Oracle to_date()函数的用法 to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,供您参考学习. 在Orac ...
- Oracle over函数
Oracle over函数 SQL code: sql over的作用及用法RANK ( ) OVER ( [query_partition_clause] order_by_clause )DE ...
- Oracle常用函数
前一段时间学习Oracle 时做的学习笔记,整理了一下,下面是分享的Oracle常用函数的部分笔记,以后还会分享其他部分的笔记,请大家批评指正. 1.Oracle 数据库中的to_date()函数的使 ...
- Oracle SQL函数
Oracle将函数大致分为单行函数,聚合函数和分析函数. 单行函数分为字符函数,日期函数,转换函数,数字函数,通用函数,decode函数 一.字符函数 1)大小写控制函数 01.Lower() 全部小 ...
- Oracle trunc()函数的用法
Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...
- oracle中函数和存储过程的区别和联系【转载竹沥半夏】
oracle中函数和存储过程的区别和联系[转载竹沥半夏] 在oracle中,函数和存储过程是经常使用到的,他们的语法中有很多相似的地方,但也有自己的特点.刚学完函数和存储过程,下面来和大家分享一下自己 ...
随机推荐
- 使用guava cache在本地缓存热点数据
某些热点数据在短时间内可能会被成千上万次访问,所以除了放在redis之外,还可以放在本地内存,也就是JVM的内存中. 我们可以使用google的guava cache组件实现本地缓存,之所以选择gua ...
- AGC028E High Elements 贪心、DP、线段树
传送门 看到要求"字典序最小"的方案,一个很直观的想法是按位贪心,那么我们需要check的就是当某一个数放在了第一个序列之后是否还存在方案. 假设当前两个序列的最大值和前缀最值数量 ...
- python3基础之“函数(2)”
1.def:定义一个函数 def f(x): return x+1 #返回函数值 a=f(2) print(a) >>3 def even_odd(x): if x%2==0: " ...
- iOS数组遍历
对于一个数组 NSArray *array = @[@"111",@"222",@"333",@"444",@" ...
- iOS 关键词assign、strong、copy、weak、unsafe_unretained
关键词assign.strong.copy.weak.unsafe_unretained 影响: 是否开辟新的内存 是否有引用计数增加 strong 指向并拥有该对象.其修饰的对象引用计数会 +1,该 ...
- AI人脸识别SDK接入 — 参数优化篇(虹软)
引言 使用了虹软公司免费的人脸识别算法,感觉还是很不错的,当然,如果是初次接触的话会对一些接口的参数有些疑问的.这里分享一下我对一些参数的验证结果(这里以windows版本为例,linux.andro ...
- Http状态码502问题复盘
问题原因分析:502 bade gateway 一般都是upstream出错,对于PHP,造成502的原因常见的就是脚本执行超过timeout设置时间,或者timeout设置过大,导致PHP进程长时间 ...
- Java之Math类使用小结
Java的Math类封装了很多与数学有关的属性和方法,大致如下: public class Main { public static void main(String[] args) { // TOD ...
- 【hbase】hbase理论学习
HBase用途: 基于Hadoop Distributed File System,是一个开源的,基于列存储模型的分布式数据库. HBase简介: HBase是一个分布式的.多版本的.面向列的开源数据 ...
- array_reduce() 与 array_map()
相似部分: 二者同为 处理数组函数,可遍历 数组中的每一个元素, 对其通过 function callback(){} 处理. 不同处: 参数: array_reduce( array, callba ...