在一组日期范围中找到差距的方法是什么?
例如,我有这些日期范围:
1/ 1/11 - 1/10/11
1/13/11 - 1/15/11
1/20/11 - 1/30/11
然后我的开始和结束日期为1/7/11和1/14/11。
我希望能够说明在2011年1月10日至2011年1月13日之间存在差距,因此无法开始和结束日期。或者我想只将日期空间返回到遇到的第一个空隙。
如果可以在SQL服务器中完成这项工作,那就很好。
我正在考虑经历每个日期,以确定它是否落在了一个日期...如果没有,那么那天就有差距。
答案 0 :(得分:2)
*I want to be able to tell that
between 1/10/11 and 1/13/11 there is
a gap so the start and end date is*
不可能。*I want to return only
the datespans up to the first gap
encountered.*
首先,这是一个讨论的虚拟表
create table spans (date1 datetime, date2 datetime);
insert into spans select '20110101', '20110110';
insert into spans select '20110113', '20110115';
insert into spans select '20110120', '20110130';
这是一个查询,它将单独列出日历中的所有日期
declare @startdate datetime, @enddate datetime
select @startdate = '20110107', @enddate = '20110114'
select distinct a.date1+v.number
from spans A
inner join master..spt_values v
on v.type='P' and v.number between 0 and datediff(d, a.date1, a.date2)
-- we don't care about spans that don't intersect with our range
where A.date1 <= @enddate
and @startdate <= A.date2
有了这个查询,我们现在可以测试是否有任何差距 计算日历中的天数与预期天数
declare @startdate datetime, @enddate datetime
select @startdate = '20110107', @enddate = '20110114'
select case when count(distinct a.date1+v.number)
= datediff(d,@startdate, @enddate) + 1
then 'No gaps' else 'Gap' end
from spans A
inner join master..spt_values v
on v.type='P' and v.number between 0 and datediff(d, a.date1, a.date2)
-- we don't care about spans that don't intersect with our range
where A.date1 <= @enddate
and @startdate <= A.date2
-- count only those dates within our range
and a.date1 + v.number between @startdate and @enddate
另一种方法是从@start构建日历 @end up to front并查看是否有这个日期的跨度
declare @startdate datetime, @enddate datetime
select @startdate = '20110107', @enddate = '20110114'
-- startdate+v.number is a day on the calendar
select @startdate + v.number
from master..spt_values v
where v.type='P' and v.number between 0
and datediff(d, @startdate, @enddate)
-- run the part above this line alone to see the calendar
-- the condition checks for dates that are not in any span (gap)
and not exists (
select *
from spans
where @startdate + v.number between date1 and date2)
查询返回日期范围@start - @end中间隙的所有日期
可以添加TOP 1
以查看是否存在空白
要返回间隙之前的所有记录,请将查询用作a 在更大的查询中派生表
declare @startdate datetime, @enddate datetime
select @startdate = '20110107', @enddate = '20110114'
select *
from spans
where date1 <= @enddate and @startdate <= date2 -- overlaps
and date2 < ( -- before the gap
select top 1 @startdate + v.number
from master..spt_values v
where v.type='P' and v.number between 0
and datediff(d, @startdate, @enddate)
and not exists (
select *
from spans
where @startdate + v.number between date1 and date2)
order by 1 ASC
)
答案 1 :(得分:1)
假设MySQL,这样的东西可以工作:
select @olddate := null;
select start_date, end_date, datediff(end_date, @olddate) as diff, @olddate:=enddate
from table
order by start_date asc, end_date asc
having diff > 1;
基本上:在@olddate变量中缓存前一行的end_date,然后使用currel enddate对该“old”值执行diff。 having子句只返回两行之差大于一天的记录。
免责声明:尚未对此进行测试,但基本查询结构应该有效。
答案 2 :(得分:1)
我希望能够在两者之间说出来 1/10/11和1/13/11之间存在差距 开始和结束日期不是 可能。
我想你问这个问题:你的表中的数据是否在开始日期和结束日期之间有差距?
我创建了一个单列表date_span,并将日期范围插入其中。
您可以通过计算开始日期和结束日期之间的天数,并将date_span中的行数与同一范围进行比较来确定差距。
select
date '2011-01-14' - date '2011-01-07' + 1 as elapsed_days,
count(*) from date_span
where cal_date between '2011-01-07' and '2011-01-14';
返回
elapsed_days count
-- --
8 6
由于它们不相等,因此2011-01-07和2011-01-14之间的表格“date_span”存在差距。我暂时停在那里,因为我真的不确定你要做什么。