oracle sql rank dense_rank row_number fisrt last
測試表emp
RANK
SQL> select EMPNO,DEPTNO,SAL,
2 rank()over(partition by DEPTNO order by SAL) "rank"
3 from emp;
EMPNO DEPTNO SAL rank
---------- ---------- ---------- ----------
7934 10 1300 1
7782 10 2450 2
7839 10 5000 3
7369 20 800 1
7876 20 1100 2
7566 20 2975 3
7788 20 3000 4
7902 20 3000 4
7900 30 950 1
7654 30 1250 2
7521 30 1250 2
7844 30 1500 4
7499 30 1600 5
7698 30 2850 6
14 rows selected.
按照deptno分組sal升序排列,這裡注意到deptno=30的sal=1250的兩個僱員,並列在該組中排名第2。然後下一個就是第4名。
What we see here is where two people have the same salary they are assigned the same rank. When multiple rows share the same rank the next rank in the sequence is not consecutive
如果兩個人有相同的salary,就分配相同的排名。多行共享了相同的排名之後,下一個排名在順序上是不連續的。
要和後面的dense_rank(),row_number()區分。
DENSE_RANK
The DENSE_RANK function acts like the RANK function except that it assigns consecutive ranks.
DENSE_RANK函數和RANK函數相似,如果有多個人有相同的salary,會分配same rank,不同之處在于下一個排名在順序上是連續的。
SQL> select EMPNO,DEPTNO,SAL,
2 dense_rank()over(partition by DEPTNO order by SAL) "rank"
3 from emp;
EMPNO DEPTNO SAL rank
---------- ---------- ---------- ----------
7934 10 1300 1
7782 10 2450 2
7839 10 5000 3
7369 20 800 1
7876 20 1100 2
7566 20 2975 3
7788 20 3000 4
7902 20 3000 4
7900 30 950 1
7654 30 1250 2
7521 30 1250 2
7844 30 1500 3
7499 30 1600 4
7698 30 2850 5
14 rows selected.
ROW_NUMBER
row_number函數的區別在於,當多個人有相同的salary的時候并不會共享rank,而是連續的分配rank。not same rank,not consecutive
SQL> select EMPNO,DEPTNO,SAL,
2 row_number()over(partition by DEPTNO order by SAL) "rank"
3 from emp;
EMPNO DEPTNO SAL rank
---------- ---------- ---------- ----------
7934 10 1300 1
7782 10 2450 2
7839 10 5000 3
7369 20 800 1
7876 20 1100 2
7566 20 2975 3
7788 20 3000 4
7902 20 3000 5
7900 30 950 1
7654 30 1250 2
7521 30 1250 3
7844 30 1500 4
7499 30 1600 5
7698 30 2850 6
14 rows selected.
FIRST and LAST
The FIRST and LAST functions can be used to return the first or last value from an ordered sequence
用於返回first 或者last value
SQL> select EMPNO,DEPTNO,SAL,
2 min(sal)keep(dense_rank first order by sal )over(partition by DEPTNO) "Lowest",
3 max(sal)keep(dense_rank last order by sal )over(partition by DEPTNO) "Highest"
4 from emp;
EMPNO DEPTNO SAL Lowest Highest
---------- ---------- ---------- ---------- ----------
7782 10 2450 1300 5000
7839 10 5000 1300 5000
7934 10 1300 1300 5000
7566 20 2975 800 3000
7902 20 3000 800 3000
7876 20 1100 800 3000
7369 20 800 800 3000
7788 20 3000 800 3000
7521 30 1250 950 2850
7844 30 1500 950 2850
7499 30 1600 950 2850
7900 30 950 950 2850
7698 30 2850 950 2850
7654 30 1250 950 2850
14 rows selected.
下面這種寫法,返回結果和上面一樣。
SQL> select EMPNO,DEPTNO,SAL,
2 min(sal)over(partition by DEPTNO) "Lowest",
3 max(sal)over(partition by DEPTNO) "Highest"
4 from emp;
EMPNO DEPTNO SAL Lowest Highest
---------- ---------- ---------- ---------- ----------
7782 10 2450 1300 5000
7839 10 5000 1300 5000
7934 10 1300 1300 5000
7566 20 2975 800 3000
7902 20 3000 800 3000
7876 20 1100 800 3000
7369 20 800 800 3000
7788 20 3000 800 3000
7521 30 1250 950 2850
7844 30 1500 950 2850
7499 30 1600 950 2850
7900 30 950 950 2850
7698 30 2850 950 2850
7654 30 1250 950 2850
14 rows selected.
2016-04-13
oracle sql rank dense_rank row_number fisrt last的更多相关文章
- [转]oracle分析函数Rank, Dense_rank, row_number
oracle分析函数Rank, Dense_rank, row_number 分析函数2(Rank, Dense_rank, row_number) 目录 ==================== ...
- Oracle分析函数 — rank, dense_rank, row_number用法
本文通过例子演示了Oracle分析函数 —— rank, dense_rank, row_number的用法. //首先建score表 create table score( course nva ...
- oracle分析函数Rank, Dense_rank, row_number
http://www.cnblogs.com/wuyisky/archive/2010/02/24/oracle_rank.html 目录=============================== ...
- Oracle 的开窗函数 rank,dense_rank,row_number
1.开窗函数和分组函数的区别 分组函数是指按照某列或者某些列分组后进行某种计算,比如计数,求和等聚合函数进行计算. 开窗函数是指基于某列或某些列让数据有序,数据行数和原始数据数相同,依然能曾现个体数据 ...
- rank,dense_rank,row_number使用和区别
rank,dense_rank,row_number区别 一:语法(用法): rank() over([partition by col1] order by col2) dense ...
- 【DB2】DB2中rank(),dense_rank(),row_number()的用法
1.准备测试数据 DROP TABLE oliver_1; ),SUB_NO ),SCORE int); ,,); ,,); ,,); ,,); ,,); ,,); 2.详解rank(),dense_ ...
- [z]一个SQL语句分清楚RANK(),DENSE_RANK(),ROW_NUMBER()三个排序的不同
转自:http://blog.csdn.net/s630730701/article/details/51902762 在SCOTT用户下,执行下面SQL; SELECT s.deptno,s.ena ...
- rank() | dense_rank() | row_number() over(PARTITION BY sex order by age desc ) 的区别
1.row_num() over()函数:根据某个字段排序后编号1,2,3.. select *,ROW_NUMBER() over ( order by majorid) as numfrom St ...
- Oracle 排序分析函数之ROW_NUMBER、RANK和DENSE_RANK
我们都知道分析函数功能很强大,可能需要写很复杂的标准SQL才能办到或不可能办到的事,使用分析函数却能很容易完成.我们经常会用到排序分析函数,如ROW_NUMBER,RANK,DENSE_RANK.这三 ...
随机推荐
- Java验证码识别解决方案
建库,去重,切割,识别. package edu.fzu.ir.test; import java.awt.Color; import java.awt.image.BufferedImage; im ...
- 10. JEB1.5 插件编写二
一些实例 1. 遍历当前光标处函数所有的Element Java代码: import java.io.*; import java.util.List; import jeb.api.IScript; ...
- kill新号专题
一.在tomcat启动脚本中看到,kill -3
- Minimum Height Trees
For a undirected graph with tree characteristics, we can choose any node as the root. The result gra ...
- JQ添加标签
<script type="text/javascript" src="http://files.cnblogs.com/914556495wxkj/jquery- ...
- POJ 1979
这是一道比较水的DPS的题目 题意就是求你可以走到的黑色的地板砖的块数,@代表你的起点,也是黑色的地板砖,#代表白色的,则说明你不能走,这就是一个广搜的题目 思路也很简单,如果你周围的那块地板是黑色的 ...
- c++转义字符、指针
上篇博客的答案: 1: // DataTypeDemo.cpp : 定义控制台应用程序的入口点. 2: // 3: 4: #include "stdafx.h" 5: #incl ...
- C++中string,wstring,CString的基本概念和用法
一.概念 string和CString均是字符串模板类,string为标准模板类(STL)定义的字符串类,已经纳入C++标准之中.wstring是操作宽字符串的类.C++标准程序库对于string的设 ...
- ios xib 中的 size class
需要阅读UITraitCollection的说明文档,先截图如下: 今天说说xib中的size class的简单设置,先看图 一共有9个小块,水平方向代表width,垂直方向代表height. 对于w ...
- ACM/ICPC 之 数据结构-线段树思想(POJ2182,含O(n^2)插入式解法)
这道题在一定程度上体现了线段树的一种用法,解决的问题是:对于总计n个元素的第i个元素,已知其在[1,i]上部分序列的排名,求第i个元素在所有n个元素中的排名. 当然这道题数据比较水,所以用O(n^2) ...