sql >> Databasteknik >  >> RDS >> Sqlserver

Tidsskillnadsberäkning i SQL Server

Använd Row_number att beställa ditt bord. Gå sedan med föregående rad för att jämföra

with cte as (
    select
        *, row_number() over (partition by [Emp ID] order by time) rn
    from
        Timecal
)

select
    a.[Emp ID], a.time, status = case when datediff(hh, b.time, a.time) < 5 then 0 else 1 end
from
    cte a
    left join cte b on a.[Emp ID] = b.[Emp ID] and a.rn - 1 = b.rn



  1. Rätt sätt att använda NOT IN Postgres

  2. Förstå DROP TABLE-satsen i SQL Server

  3. Hur man formaterar ett tal som valuta i Oracle

  4. PostgreSQL-grupperingsfel