第一步:排序
SELECT * FROM TABLE1 ORDER BY ID
第二步:日期-ROWNUM如果相同的话认为他们是连续的,然后GORUP BY一下
SELECT A.*,(SUBSTR(TO_CHAR(A.RQ,'YYYYMMDD'),0,4)*12+SUBSTR(TO_CHAR(A.RQ,''YYYYMMDD'),5,2) -ROWNUM) DAYS
FROM (SELECT * FROM TABLE1 ORDER BY ID) A
第三步:分别求出连续区间,让他们相减求出大于N的值
SELECT B.ID,MAX(B.RQ),MIN(B.RQ), DAYS
FROM (SELECT A.*,(SUBSTR(TO_CHAR(A.RQ,'YYYYMMDD'),0,4)*12+SUBSTR(TO_CHAR(A.RQ,''YYYYMMDD'),5,2) -ROWNUM) DAYS
FROM (SELECT * FROM TABLE1 ORDER BY ID) A ) B
GROUP BY B.ID, B.DAYS
HAVING COUNT(*)>N
本文介绍了一个SQL查询技巧,通过排序、日期处理和分组操作,实现对连续日期区间的识别与计算。具体步骤包括排序、日期转换为连续编号、分组并计算日期差值,最后筛选出连续日期数超过特定阈值的区间。

1032

被折叠的 条评论
为什么被折叠?



