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

Registrer huller over 30 minutter i tidsstempelkolonnen

Nem løsning med almindeligt tabeludtryk. Sammenlign med markørens ydeevne, hvis du har mindst 1000 rækker.

create table #tmp (Dt datetime)

insert into #tmp values 
('2015-07-15 15:01:21'),
('2015-07-15 15:17:44'), 
('2015-07-15 15:17:53'), 
('2015-07-15 15:18:34'), 
('2015-07-15 15:21:41'), 
('2015-07-15 15:58:12'), 
('2015-07-15 15:59:12'), 
('2015-07-15 16:05:12'),
('2015-07-15 17:02:12')

;with tbl as (
select dt, row_number() over(order by dt) rn
from #tmp
)
select t1.dt [from],t2.dt [to], datediff(minute,t1.dt,t2.dt) gap
from tbl t1 
inner join tbl t2 on t1.rn+1 = t2.rn
where datediff(minute,t1.dt,t2.dt) >30


  1. Ulovlig blanding af sorteringsfejl i MySql

  2. Kan ikke løse tabelnavn tæt på

  3. Giver Oracle muligheden for at returnere flere understrenge fra en streng/klob-række, der er blevet parset?

  4. Dvale-undtagelse på MySQL Cross Join Query