Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Conta valori duplicati consecutivi in ​​SQL

Presumo che id è unico e crescente. È possibile ottenere conteggi di valori consecutivi utilizzando i diversi numeri di riga. Quanto segue conta tutte le sequenze:

select grp, value, min(id), max(id), count(*) as cnt
from (select t.*,
             (row_number() over (order by id) - row_number() over (partition by value order by id)
             ) as grp
      from table t
     ) t
group by grp, value;

Se vuoi la sequenza più lunga di 0:

select top 1 grp, value, min(id), max(id), count(*) as cnt
from (select t.*,
             (row_number() over (order by id) - row_number() over (partition by value order by id)
             ) as grp
      from table t
     ) t
group by grp, value
having value = 0
order by count(*) desc