一、ROW_NUMBER()
SELECT ITEM_CODE,
PO_NO,
PO_LINE_NO,
PO_AMT,
ROW_NUMBER() OVER(PARTITION BY PO_NO ORDER BY ITEM_CODE) AS NUM
FROM MRO.STX_MRO_PO_LINE
WHERE PO_NO='RP111110-0016';
执行结果:
ITEM_CODE |
PO_NO |
PO_LINE_NO |
PO_AMT |
NUM |
M90202-0023 |
RP111110-0016 |
9 |
188000 |
1 |
M90202-0023 |
RP111110-0016 |
5 |
235000 |
2 |
M90202-0028 |
RP111110-0016 |
10 |
33440 |
3 |
M90202-0057 |
RP111110-0016 |
6 |
6380 |
4 |
M90202-0167 |
RP111110-0016 |
8 |
325600 |
5 |
M90202-0167 |
RP111110-0016 |
7 |
130240 |
6 |
M90205-0011 |
RP111110-0016 |
1 |
1920 |
7 |
M90205-0015 |
RP111110-0016 |
2 |
9120 |
8 |
M90205-0016 |
RP111110-0016 |
3 |
16500 |
9 |
M90205-0017 |
RP111110-0016 |
4 |
2986 |
10 |
二、RANK()
SELECT ITEM_CODE,
PO_NO,
PO_LINE_NO,
PO_AMT,
RANK() OVER(PARTITION BY PO_NO ORDER BY ITEM_CODE) AS NUM
FROM MRO.STX_MRO_PO_LINE
WHERE PO_NO='RP111110-0016';
执行结果:
ITEM_CODE |
PO_NO |
PO_LINE_NO |
PO_AMT |
NUM |
M90202-0023 |
RP111110-0016 |
9 |
188000 |
1 |
M90202-0023 |
RP111110-0016 |
5 |
235000 |
1 |
M90202-0028 |
RP111110-0016 |
10 |
33440 |
3 |
M90202-0057 |
RP111110-0016 |
6 |
6380 |
4 |
M90202-0167 |
RP111110-0016 |
8 |
325600 |
5 |
M90202-0167 |
RP111110-0016 |
7 |
130240 |
5 |
M90205-0011 |
RP111110-0016 |
1 |
1920 |
7 |
M90205-0015 |
RP111110-0016 |
2 |
9120 |
8 |
M90205-0016 |
RP111110-0016 |
3 |
16500 |
9 |
M90205-0017 |
RP111110-0016 |
4 |
2986 |
10 |
三、DENSE_RANK()
SELECT ITEM_CODE,
PO_NO,
PO_LINE_NO,
PO_AMT,
DENSE_RANK() OVER(PARTITION BY PO_NO ORDER BY ITEM_CODE) AS NUM
FROM MRO.STX_MRO_PO_LINE
WHERE PO_NO='RP111110-0016';
执行结果:
ITEM_CODE |
PO_NO |
PO_LINE_NO |
PO_AMT |
NUM |
M90202-0023 |
RP111110-0016 |
9 |
188000 |
1 |
M90202-0023 |
RP111110-0016 |
5 |
235000 |
1 |
M90202-0028 |
RP111110-0016 |
10 |
33440 |
2 |
M90202-0057 |
RP111110-0016 |
6 |
6380 |
3 |
M90202-0167 |
RP111110-0016 |
8 |
325600 |
4 |
M90202-0167 |
RP111110-0016 |
7 |
130240 |
4 |
M90205-0011 |
RP111110-0016 |
1 |
1920 |
5 |
M90205-0015 |
RP111110-0016 |
2 |
9120 |
6 |
M90205-0016 |
RP111110-0016 |
3 |
16500 |
7 |
M90205-0017 |
RP111110-0016 |
4 |
2986 |
8 |
分享到:
相关推荐
ROW_NUMBER、RANK、DENSE_RANK 和 NTILE 排名函数 MS SQL 2005 中的排名函数包括 ROW_NUMBER、RANK、DENSE_RANK 和 NTILE,这四个函数可以有效地分析数据并提供排序值。下面将详细介绍每个函数的用法和示例。 一、...
- `row_number`:为每一行生成一个唯一的序号,不受相同值的影响。 - `rank`:在考虑相同值的情况下分配序号,出现相同值时跳过序号。 - `dense_rank`:同样考虑相同值,但保证序号的连续性,不会跳过序号。 - `...
### 分析函数ROW_NUMBER、RANK、DENSE_RANK的用法 #### 一、ROW_NUMBER()函数 **ROW_NUMBER()** 函数是SQL Server 2005引入的一个新的窗口函数,它为每一行返回一个唯一的整数值。该函数特别适用于需要对查询结果...
`ROW_NUMBER()`可以与`RANK()`和`DENSE_RANK()`进行比较。这些函数都可以用来给数据排序并分配等级,但是它们在处理并列的情况时有所不同: - **Rank**:如果两个或多个行具有相同的排序值,则这些行都将获得相同...
在这篇文档中,我们将详细学习在Hive中如何进行分组取topN,以及如何使用row_number()、rank()和dense_rank()三种窗口函数进行数据排序和排名。 首先,Hive中的数据表创建和数据插入操作是数据查询和分析的前提。...
Oracle分析函数Rank、Dense_rank和row_number是用于处理数据集的高级工具,它们在数据库查询中发挥着关键作用,特别是在需要对数据进行排序和分组时。这三种函数都有各自的特点,适用于不同的业务场景。 1. **row_...
在SQL Server 2005中,`ROW_NUMBER()`、`RANK()`和`DENSE_RANK()`是三种常用的排名函数,它们在处理大数据集时非常有用,尤其在数据分析和报表生成方面。这些函数都可以帮助我们根据指定的条件对数据进行排序并赋予...
“rank()、dense_rank()和row_number()的区别”文章的date
`rank()`和`dense_rank()`函数是`row_number()`的两个变体: - **rank()**:类似`row_number()`,但它在遇到相等的排序值时会产生跳跃。也就是说,如果有两个行在排序列上有相同的值,它们都会被赋予相同的排名,接...
本文主要讲解SQL中的四大排名函数:ROW_NUMBER、RANK、DENSE_RANK以及NTILE,它们在数据分析和报表生成中起到关键作用。 1. ROW_NUMBER() ROW_NUMBER()函数用于为查询结果集中的每一行分配一个唯一的数字序列。这个...
此外,`ROW_NUMBER()`函数还有其他窗口函数,如`RANK()`和`DENSE_RANK()`,它们在某些场景下可能会提供更灵活的解决方案。但在这里,我们主要关注`ROW_NUMBER()`在分页中的应用。 总结起来,`ROW_NUMBER()`函数在...
`row_number()`, `rank()`, 和 `dense_rank()` 是三个重要的窗口函数,用于为查询结果集中的每一行分配唯一的序列号,常用于分组、排名或者实现分区排序。下面我们将详细探讨这三个函数的区别和用法。 1. `row_...
在实际工作中,理解和掌握ROW_NUMBER()、RANK()和DENSE_RANK()的区别至关重要,能够帮助我们编写更高效、精确的SQL查询,从而优化数据处理和分析流程。通过阅读"The-Difference-Between-ROW-NUMBER-RANK-and-DENSE-R...
SQL Server 2005 中提供了四个排名函数,分别是 row_number、rank、dense_rank 和 ntile。这四个函数的主要功能是为查询结果生成一个序号,用于实现查询指定范围的记录或实现分页功能。 一、row_number 函数 row_...