Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/74.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 在一组日期跨度中找出差距的好方法是什么?_Sql_Sql Server_Gaps And Islands - Fatal编程技术网

Sql 在一组日期跨度中找出差距的好方法是什么?

Sql 在一组日期跨度中找出差距的好方法是什么?,sql,sql-server,gaps-and-islands,Sql,Sql Server,Gaps And Islands,在一组日期跨度中查找差距的方法是什么 例如,我有以下日期跨度: 1/ 1/11 - 1/10/11 1/13/11 - 1/15/11 1/20/11 - 1/30/11 然后我有一个开始和结束日期1/7/11和1/14/11 我想知道11年1月10日和11年1月13日之间有一段时间间隔,所以开始和结束日期是不可能的。或者我只想返回到遇到的第一个间隔的日期跨度 如果这可以在SQL server中完成,那就太好了 我在想每一次约会,看看它是否落在一个日期范围内。。。如果没有,那么那天就会

在一组日期跨度中查找差距的方法是什么

例如,我有以下日期跨度:

1/ 1/11 - 1/10/11  
1/13/11 - 1/15/11  
1/20/11 - 1/30/11
然后我有一个开始和结束日期1/7/11和1/14/11

我想知道11年1月10日和11年1月13日之间有一段时间间隔,所以开始和结束日期是不可能的。或者我只想返回到遇到的第一个间隔的日期跨度

如果这可以在SQL server中完成,那就太好了


我在想每一次约会,看看它是否落在一个日期范围内。。。如果没有,那么那天就会有一个间隙。

假设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变量中,然后用currel enddate对“old”值进行区分。having子句将只返回两行之间的差值大于一天的记录

免责声明:我们尚未对此进行测试,但基本查询构造应该可以工作

我想能够分辨出这两者之间的区别 2011年1月10日和2011年1月13日之间存在差距,因此 开始和结束日期不正确 可能

我想你是在问这样一个问题:表中的数据在开始日期和结束日期之间有差距吗

我创建了一个单列表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之间的“日期跨度”表中存在差距。我现在就到此为止,因为我真的不确定你想做什么

  • 跳转到第二个最后一个代码块:
    *我想知道
    11年10月1日至11年13月1日之间有
    间隔,因此开始和结束日期为*
    不可能
  • 跳转到的最后一个代码块:
    *我只想返回
    日期一直延伸到第一个间隔
    遇到。*
首先,这里有一个虚拟表要讨论

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
查询返回日期范围@start-@end中的所有日期间隔 可以添加一个
TOP 1
,以查看是否存在间隙

要返回间隙之前的所有记录,请将查询用作 较大查询中的派生表

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
)
声明@startdate datetime,@enddate datetime
选择@startdate='20110107',@enddate='20110114'
挑选*
从跨度
日期1
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)
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
)