sql >> Database >  >> RDS >> Sqlserver

Detecteer hiaten van meer dan 30 minuten in de tijdstempelkolom

Eenvoudige oplossing met behulp van gemeenschappelijke tabeluitdrukkingen. Vergelijk met cursorprestaties als u minimaal 1000 rijen heeft.

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. Samengestelde OF SQL-query (query #1 met WITH) en (query #2) met COUNT() excusions

  2. MySQL-limiet met variabele

  3. MySQL met C#, vanuit het standpunt van een PHP-ontwikkelaar

  4. Hoeveel significante cijfers moet ik in mijn database opslaan voor een GPS-coördinaat?