sql >> Databáze >  >> RDS >> Sqlserver

Jak mohu na serveru SQL určit, zda se rozsah dateTime překrývá s jiným

Můžete to udělat takto

declare @T table (ID int, startDateTime datetime, endDateTime datetime)

insert into @T values
(  1 , '2010-01-01 10:30:00' , '2010-01-01 11:00:00'),
(  2 , '2010-01-01 10:30:00' , '2010-01-01 11:30:00'),
(  3 , '2010-01-01 11:00:00' , '2010-01-01 11:30:00'),
(  4 , '2010-01-01 11:00:00' , '2010-01-01 12:00:00'),
(  5 , '2010-01-01 11:30:00' , '2010-01-01 12:00:00')

declare @startDateTime datetime
declare @endDateTime datetime


set @startDateTime = '2010-01-01 11:00:00'
set @endDateTime = '2010-01-01 11:30:00'

select *
from @T
where
  startDateTime < @endDateTime and
  endDateTime > @startDateTime



  1. Jak získat aktuální datum (bez času) v T-SQL

  2. 2 způsoby, jak vrátit seznam propojených serverů v SQL Server pomocí T-SQL

  3. Nainstalujte SQL Server 2016

  4. Jak získat záznam s maximální hodnotou v MySQL