在SQL中给出日期范围,查找第一个可用日期

时间:2014-10-29 22:43:41

标签: sql sql-server date

假设您有一个表格,其中包含日期范围,这些日期不可用。

+------------+------------+
| StartDate  | EndDate    |
+------------+------------+
| 2014-10-1  | 2014-10-15 |
+------------+------------+
| 2014-11-4  | 2014-11-28 |
+------------+------------+
| 2014-12-17 | NULL       |
+------------+------------+

NULL的EndDate表示直到时间结束。所以在12月17日之后没有可用的日期。

鉴于日期范围,我需要找到第一个可用日期。我在SQL上并不是那么出色,我无法想象如何做到这一点。

实施例: 给定期望的日期范围

2014-10-13至2014-11-17,查询应返回2014-10-16

2014-10-13至2014-11-30,查询应返回2014-10-16

2014-10-21至2014-11-30,查询应返回2014-10-21

2014-12-01至2015-1-13,查询应返回2014-12-01

我很感激任何帮助。感谢。

1 个答案:

答案 0 :(得分:1)

试试这个,没有循环! (顺便说一句,你的最后一个测试用例 错了我相信)

CREATE TABLE [dbo].[Dates]([StartDate] [datetime] NULL, [EndDate] [datetime] NULL ) ON [PRIMARY]

INSERT INTO [dbo].[Dates]([StartDate], [EndDate])
SELECT '20141001 00:00:00.000', '20141015 00:00:00.000' UNION ALL
SELECT '20141104 00:00:00.000', '20141128 00:00:00.000' UNION ALL
SELECT '20141217 00:00:00.000', NULL

DECLARE @Date1 DATETIME;
DECLARE @Date2 DATETIME;

-- Test case 1
SET @Date1 = '2014-10-13';
SET @Date2 = '2014-11-17';

-- Test case 2
SET @Date1 = '2014-10-13';
SET @Date2 = '2014-11-30';

-- Test case 3
SET @Date1 = '2014-10-21';
SET @Date2 = '2014-11-30';

-- Test case 4
SET @Date1 = '2014-12-01';
SET @Date2 = '2015-01-13';

-- Generate a temp table of dates from @Date1 to @Date2
SELECT TOP (DATEDIFF(DAY, @Date1, @Date2)+1)
  [date] = DATEADD(day, ROW_NUMBER() OVER (ORDER BY [object_id]) - 1, @Date1)
INTO
  #DateRange
FROM
  sys.all_objects

-- Remove non-available dates
DELETE #DateRange  
WHERE  
  EXISTS(SELECT 1 FROM dbo.Dates WHERE date BETWEEN StartDate AND ISNULL(EndDate, date))

-- Select first available date  
SELECT TOP 1 * FROM #DateRange AS dr ORDER BY date