我正在研究 PLSQL (Oracle 12) 的查询,其中我需要增加每个组的数据集的行号。
我的问题与这个问题类似(增加组上的行号 https://stackoverflow.com/questions/11116275/increment-row-number-on-group)。但是,我的情况略有不同。我有同样的shade重复数据,并且我想在分组时保留原始顺序。
对于下面的数据
Level | Shade
-------------
1 | A
2 | A
3 | A
4 | B
5 | B
6 | B
7 | A
8 | A
9 | A
我想得到以下结果
Group | Shade | Amount
----------------------
1 | A | 3
2 | B | 3
3 | A | 3
如果我使用 DENSE_RANK 函数排序Shade,我无法保留原始订单,这就是我得到的:
Group | Shade | Amount
----------------------
1 | A | 6
2 | B | 3
分组时如何保持原来的分组模式?
您可以使用行号的差异来定义组:
select Shade, count(*) as amount
from (select t.*,
row_number() over (order by level) as seqnum,
row_number() over (partition by shade order by level) as seqnum_s
from t
) t
group by Shade, (seqnum - seqnum_s);
有点难以解释为什么会这样。如果您查看子查询的结果,就会很明显地看出为什么两者之间存在差异row_number()
值标识连续的组。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)