2

我有一个约会表,其中包含许多“资源”的约会,我需要做的是查询并返回(对于特定资源)一个日期范围内的所有免费约会空档。

我曾认为解决此问题的最佳方法是生成一个可能的约会时间的临时表(因为约会的长度可能是 30/60/90 分钟 - 将为查询指定约会长度。)然后选择这两个记录集的交集。即所有这些 - 在日期范围内 - 在约会表中没有约会。从而返回该资源的所有可能约会。

或者也许只是 - 再次 - 生成可能的约会日期时间的记录,然后除了已经预订的实际约会......?

除非当然有人可以提出更简单的选择。?

也不完全确定如何生成可能的表格,即带有记录的表格2010-12-08 09:00, 2010-12-08 10:00,等等(1小时约会)......

有任何想法吗?

编辑:对可能性有一个模糊的想法......

DECLARE @startDate DateTime
DECLARE @EndDate DateTime

set @startDate = '2010-12-08 09:00'
set @endDate = '2010-12-11 09:00';

with mycte as
(
   select cast(@startDate as datetime) DateValue
   union all
   select dateadd(mi,30,DateValue)
   from    mycte   
   where   DateValue <= @endDate
   and datepart(hh, dateadd(mi,30,DateValue)) Between 9 AND 16

)
select DateValue
from    mycte
4

1 回答 1

1

这是一个典型的差距和孤岛问题。它本质上是一个常见问题,您需要在序列中识别缺失值(间隙)。幸运的是,Manning 的书 SQL Server MVP Deep Dives 中有一个关于这个主题的免费示例章节。希望它能提供灵感,因为它为许多可能的方法提供指导。

http://www.manning.com/nielsen/SampleChapter5.pdf

这是 Itzik Ben-Gan 对问题的描述,引用自上一章。

间隙和孤岛问题涉及序列中的缺失值……所涉及的序列也可以是时间性的,例如订单日期,其中一些由于不活动期间(周末、节假日)而缺失。寻找不活动时期是间隙问题的一个例子,寻找活动时期是孤岛问题的一个例子。

于 2010-12-08T10:14:08.640 回答