sql >> Database teknologi >  >> RDS >> Oracle

Hvordan tæller man på hinanden følgende dubletter i en tabel?

Det kan gøres med Tabibitosan-metoden. Kør dette for at forstå det:

with a as(
select 1 slno, 'A' pg from dual union all
select 2 slno, 'A' pg from dual union all
select 3 slno, 'B' pg from dual union all
select 4 slno, 'A' pg from dual union all
select 5 slno, 'A' pg from dual union all
select 6 slno, 'A' pg from dual 
)
select slno, pg, newgrp, sum(newgrp) over (order by slno) grp
from( 
    select slno, 
           pg, 
           case when pg <> nvl(lag(pg) over (order by slno),1) then 1 else 0 end newgrp
    from a
    );

Newgrp betyder, at en ny gruppe er fundet.

Resultat:

SLNO PG NEWGRP GRP
1    A  1      1
2    A  0      1
3    B  1      2
4    A  1      3
5    A  0      3
6    A  0      3

Nu skal du bare bruge en gruppe efter med tæller for at finde gruppen med det maksimale antal forekomster:

with a as(
select 1 slno, 'A' pg from dual union all
select 2 slno, 'A' pg from dual union all
select 3 slno, 'B' pg from dual union all
select 4 slno, 'A' pg from dual union all
select 5 slno, 'A' pg from dual union all
select 6 slno, 'A' pg from dual 
),
b as(
select slno, pg, newgrp, sum(newgrp) over (order by slno) grp
from( 
    select slno, pg, case when pg <> nvl(lag(pg) over (order by slno),1) then 1 else 0 end newgrp
    from a
    )
)
select max(cnt)
from (
    select grp, count(*) cnt
    from b
    group by grp
    );


  1. ORDER BY id eller date_created for at vise de seneste resultater?

  2. orakelvisninger og netværkstrafik

  3. Hvordan bruger jeg kaskadesletning med SQL Server?

  4. Trækker tidsstemplet i oracle og returnerer mærkelige data