Oracle-分析函数之排序后顺序号row_number()

简介: Oracle-分析函数之排序后顺序号row_number()

语法


【语法】

ROW_NUMBER() OVER (PARTITION BY COL1 ORDER BY COL2)


【功能】表示根据COL1分组,在分组内部根据 COL2排序,而这个值就表示每组内部排序后的顺序编号(组内连续的唯一的)

row_number() 返回的主要是“行”的信息,并没有排名.

【参数】

【说明】Oracle分析函数

【主要功能】:用于取前几名,或者最后几名等


栗子

表内容如下:

name | seqno | description
A | 1 | xgj
A | 2 | xgj
A | 3 | xgj
A | 4 | xgj
B | 1 | xgj
B | 2 | xgj
B | 3 | xgj
B | 4 | xgj
C | 1 | xgj
C | 2 | xgj
C | 3 | xgj
C | 4 | xgj


我想有一个sql语句,搜索的结果是

A | 1 | xgj
A | 2 | xgj
B | 1 | xgj
B | 2 | xgj
C | 1 | xgj
C | 2 | xgj


SQL:

select name, seqno, description
  from (select name,
               seqno,
               description,
               row_number() over(partition by name order by seqno) id
          from table_name)
 where id <= 3;


相关文章
|
8月前
|
SQL 存储 Oracle
【YashanDB知识库】Oracle pipelined函数在YashanDB中的改写
【YashanDB知识库】Oracle pipelined函数在YashanDB中的改写
|
SQL Oracle 算法
|
SQL Oracle 关系型数据库
|
SQL Oracle 关系型数据库
Oracle|内置函数之INSTR
【7月更文挑战第5天】
|
Oracle 关系型数据库 数据挖掘
|
Oracle 关系型数据库 数据挖掘
|
存储 Oracle NoSQL
Oracle中decode函数详解
Oracle中decode函数详解
|
算法
Leetcode 313. Super Ugly Number
题目翻译成中文是『超级丑数』,啥叫丑数?丑数就是素因子只有2,3,5的数,7 14 21不是丑数,因为他们都有7这个素数。 这里的超级丑数只是对丑数的一个扩展,超级丑数的素因子不再仅限于2 3 5,而是由题目给定一个素数数组。与朴素丑数算法相比,只是将素因子变了而已,解法还是和朴素丑数一致的。
194 1
|
存储 SQL 算法
LeetCode 题目 65:有效数字(Valid Number)【python】
LeetCode 题目 65:有效数字(Valid Number)【python】
|
存储 算法
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
167 0

推荐镜像

更多