如何计算表列中连续出现的次数
处理表中的数据时,计算连续出现的次数可能很有用某个值在特定列中连续出现的次数。例如,如果表包含代表员工姓名的列,您可能想知道同一员工姓名在一行中出现的次数。
问题
考虑下表:
create table #t (Id int, Name char) insert into #t values (1, 'A'), (2, 'A'), (3, 'B'), (4, 'B'), (5, 'B'), (6, 'B'), (7, 'C'), (8, 'B'), (9, 'B')
目标是计算“Name”中每个值连续出现的次数 柱子。所需的输出是:
Name | Repetition |
---|---|
A | 2 |
B | 4 |
C | 1 |
B | 2 |
解决方案
解决此问题的一种方法是使用行号的概念,然后计算它们之间的差异来识别连续出现。以下查询演示了这种方法:
select name, count(*) from (select t.*, (row_number() over (order by id) - row_number() over (partition by name order by id) ) as grp from t ) t group by grp, name;
说明
查询中的子查询:
(select t.*, (row_number() over (order by id) - row_number() over (partition by name order by id) ) as grp from t )
计算每个的行号“t”表中的行。 row_number() 函数为每一行分配一个连续的编号,而partition by 子句确保为“Name”列中的每个不同值重置行号。这会产生“grp”列,该列指示“Name”和“Id”的每个组合的连续出现的组。
然后外部查询按“grp”列对结果进行分组并计算每个“grp”和“名称”组合出现的次数。这提供了最终结果,该结果计算“名称”列中每个值的连续出现次数。
通过利用行号之间的差异,该方法准确确定指定列中值的连续出现次数并生成所需的输出。
以上是如何计算数据库列中连续出现的值?的详细内容。更多信息请关注PHP中文网其他相关文章!