如何知道 SQL 服务器两次之间是否有一个小时
How to know if an hour this in between two times with SQL Server
我有这个:
DECLARE @HourBegin time = '18:00'
DECLARE @HourEnd time = '02:00'
DECLARE @Hour TIME = '20:00'
BEGIN TRAN
IF(@Hour between @HourBegin and @HourEnd)
BEGIN
SELECT
CONVERT(BIT, 1) AS ERROR,
'1' AS MSG
END
ELSE
BEGIN
SELECT
CONVERT(BIT,1) AS ERROR,
'0' AS MSG
END
COMMIT TRAN
问题是变量@HourEnd
是第二天然后BETWEEN
总是给我变量@Hour
不在指定范围内
!求助!
你可以这样做。如果你得到 endDate < StartDate
,你可能应该在 endDate 上增加 1 天。所以你最终得到:
DECLARE @HourBegin time = '18:00'
DECLARE @HourEnd time = '02:00'
DECLARE @Hour TIME = '19:00'
DECLARE @DateBegin DATETIME
DECLARE @DateEnd DATETIME
DECLARE @Date DATETIME
select @DateBegin = CAST(@HourBegin AS DATETIME)
select @DateEnd = CAST(@HourEnd AS DATETIME)
select @Date = CAST(@Hour AS DATETIME)
IF(@DateEnd < @DateBegin)
SET @DateEnd = DATEADD(dd, 1, @DateEnd)
BEGIN TRAN
IF(@Date between @DateBegin and @DateEnd)
BEGIN
SELECT CONVERT(BIT,1) AS ERROR, '1' AS MSG
END
ELSE
BEGIN
SELECT CONVERT(BIT,1) AS ERROR, '0' AS MSG
END
COMMIT TRAN
这是一个处理这个的函数:
CREATE function dbo.f_between
(
@HourBegin DATETIME,
@HourEnd DATETIME,
@Hour DATETIME
)RETURNS bit
as
BEGIN
RETURN CASE WHEN
@Hour between @HourBegin and @HourEnd or
((@Hour <= @HourEnd or @hour >= @HourBegin) and @HourBegin > @HourEnd)
THEN cast(1 as bit)
ELSE cast(0 as bit) END
END
这是一个如何使用它的例子:
测试数据和table:
DECLARE @t table(HourBegin time, HourEnd time, hour time)
insert @t values('06:00', '12:00', '01:00') -- not between
insert @t values('06:00', '12:00', '09:00') -- between
insert @t values('06:00', '12:00', '15:00') -- not between
insert @t values('12:00', '06:00', '01:00') -- between
insert @t values('12:00', '06:00', '09:00') -- not between
insert @t values('12:00', '06:00', '15:00') -- between
查询:
SELECT
HourBegin,
HourEnd,
hour,
dbo.f_between(HourBegin, HourEnd, hour) betweenbit
FROM @t
结果:
HourBegin HourEnd hour betweenbit
06:00:00 12:00:00 01:00:00 0
06:00:00 12:00:00 09:00:00 1
06:00:00 12:00:00 15:00:00 0
12:00:00 06:00:00 01:00:00 1
12:00:00 06:00:00 09:00:00 0
12:00:00 06:00:00 15:00:00 1
我有这个:
DECLARE @HourBegin time = '18:00'
DECLARE @HourEnd time = '02:00'
DECLARE @Hour TIME = '20:00'
BEGIN TRAN
IF(@Hour between @HourBegin and @HourEnd)
BEGIN
SELECT
CONVERT(BIT, 1) AS ERROR,
'1' AS MSG
END
ELSE
BEGIN
SELECT
CONVERT(BIT,1) AS ERROR,
'0' AS MSG
END
COMMIT TRAN
问题是变量@HourEnd
是第二天然后BETWEEN
总是给我变量@Hour
不在指定范围内
!求助!
你可以这样做。如果你得到 endDate < StartDate
,你可能应该在 endDate 上增加 1 天。所以你最终得到:
DECLARE @HourBegin time = '18:00'
DECLARE @HourEnd time = '02:00'
DECLARE @Hour TIME = '19:00'
DECLARE @DateBegin DATETIME
DECLARE @DateEnd DATETIME
DECLARE @Date DATETIME
select @DateBegin = CAST(@HourBegin AS DATETIME)
select @DateEnd = CAST(@HourEnd AS DATETIME)
select @Date = CAST(@Hour AS DATETIME)
IF(@DateEnd < @DateBegin)
SET @DateEnd = DATEADD(dd, 1, @DateEnd)
BEGIN TRAN
IF(@Date between @DateBegin and @DateEnd)
BEGIN
SELECT CONVERT(BIT,1) AS ERROR, '1' AS MSG
END
ELSE
BEGIN
SELECT CONVERT(BIT,1) AS ERROR, '0' AS MSG
END
COMMIT TRAN
这是一个处理这个的函数:
CREATE function dbo.f_between
(
@HourBegin DATETIME,
@HourEnd DATETIME,
@Hour DATETIME
)RETURNS bit
as
BEGIN
RETURN CASE WHEN
@Hour between @HourBegin and @HourEnd or
((@Hour <= @HourEnd or @hour >= @HourBegin) and @HourBegin > @HourEnd)
THEN cast(1 as bit)
ELSE cast(0 as bit) END
END
这是一个如何使用它的例子:
测试数据和table:
DECLARE @t table(HourBegin time, HourEnd time, hour time)
insert @t values('06:00', '12:00', '01:00') -- not between
insert @t values('06:00', '12:00', '09:00') -- between
insert @t values('06:00', '12:00', '15:00') -- not between
insert @t values('12:00', '06:00', '01:00') -- between
insert @t values('12:00', '06:00', '09:00') -- not between
insert @t values('12:00', '06:00', '15:00') -- between
查询:
SELECT
HourBegin,
HourEnd,
hour,
dbo.f_between(HourBegin, HourEnd, hour) betweenbit
FROM @t
结果:
HourBegin HourEnd hour betweenbit
06:00:00 12:00:00 01:00:00 0
06:00:00 12:00:00 09:00:00 1
06:00:00 12:00:00 15:00:00 0
12:00:00 06:00:00 01:00:00 1
12:00:00 06:00:00 09:00:00 0
12:00:00 06:00:00 15:00:00 1