如风的爱
2017-07-19 19:02:57
sql查询连续日期及连续的天数
create table tmptable(rq datetime) go insert tmptable values('2010.1.1') insert tmptable values('2010.1.2') insert tmptable values('2010.1.3') insert tmptable values('2010.1.6') insert tmptable values('2010.1.7') insert tmptable values('2010.1.10') insert tmptable values('2010.1.11') insert tmptable values('2010.1.12') insert tmptable values('2010.1.19') insert tmptable values('2010.1.20') insert tmptable values('2010.1.22') insert tmptable values('2010.1.23') insert tmptable values('2010.1.28') go ---希望得到的结果 --本期起始日期 本期终止日期 持续天数 距上一期天数 --2010.1.1 2010.1.3 3 0 --2010.1.6 2010.1.7 2 3 --2010.1.10 2010.1.12 3 3 --2010.1.19 2010.1.20 2 7 --2010.1.22 2010.1.23 2 2 --2010.1.28 2010.1.28 1 5 drop table tmptable go
<span style="color:rgb(69, 69, 69); font-size:14px">一句sql实现</span> select 本期起始日期=min(rq),本期终止日期=max(rq),持续天数=max(id1)-min(id1)+1, 距上一期天数=case a.id1-a.id2 when -1 then 0 else max(datediff(d,rq2,rq)) end from ( select id1=datediff(d,'2010-01-01',rq),id2=(select count(1) from tmptable where rq <= a.rq),rq2=(select max(rq) from tmptable where rq < a.rq),* from tmptable a ) a group by a.id1-a.id2 /* 本期起始日期 本期终止日期 持续天数 距上一期天数 ----------------------- ----------------------- ----------- ----------- 2010-01-01 00:00:00.000 2010-01-03 00:00:00.000 3 0 2010-01-06 00:00:00.000 2010-01-07 00:00:00.000 2 3 2010-01-10 00:00:00.000 2010-01-12 00:00:00.000 3 3 2010-01-19 00:00:00.000 2010-01-20 00:00:00.000 2 7 2010-01-22 00:00:00.000 2010-01-23 00:00:00.000 2 2 2010-01-28 00:00:00.000 2010-01-28 00:00:00.000 1 5 警告: 聚合或其他 SET 操作消除了空值。 (6 行受影响) */
评论
最近浏览
水光浮藻 LV6
2021年3月10日
wkc LV21
2020年6月28日
maclee2020 LV1
2020年4月22日
dagf113225 LV68
2019年6月28日
sky_hui LV6
2019年6月26日
茫茫人海中的小牛 LV10
2019年5月7日
cs383450139
2019年3月22日
暂无贡献等级
梦醒繁华丶 LV19
2018年4月26日
haizhan110 LV3
2018年4月20日
huayuliang2018
2018年4月11日
暂无贡献等级