假设您有一个表格,其中包含日期范围,这些日期不可用。
+------------+------------+
| 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
我很感激任何帮助。感谢。
答案 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