开发者社区> 问答> 正文

根据给定的输入获取上一个和下一个数据

我有带有示例数据的下表:

DummyData

CREATE TABLE DummyData
(
    ID int,
    Dates_Range VARCHAR(50)
);

样本数据:

INSERT INTO DummyData VALUES(1,'2019-01-01');
INSERT INTO DummyData VALUES(1,'2019-01-02');
INSERT INTO DummyData VALUES(1,'2019-01-03');
INSERT INTO DummyData VALUES(NULL,'2019-01-04 - 2019-02-01');
INSERT INTO DummyData VALUES(1,'2019-02-02');

INSERT INTO DummyData VALUES(2,'2019-01-06');
INSERT INTO DummyData VALUES(NULL,'2019-01-07');
INSERT INTO DummyData VALUES(2,'2019-01-08');
INSERT INTO DummyData VALUES(2,'2019-01-09');

INSERT INTO DummyData VALUES(3,'2019-01-02');
INSERT INTO DummyData VALUES(3,'2019-01-03');
INSERT INTO DummyData VALUES(NULL,'2019-01-04 - 2019-01-09');
INSERT INTO DummyData VALUES(3,'2019-01-10');

查询:我需要查找NULLID 之前和之后的n个数字数据。

例如1:我需要从NULLID 之前和之后找到1个数据,然后输出将是:

ID      DRange
-------------------------------
1       2019-01-03
NULL    2019-01-04 - 2019-02-01
1       2019-02-02
2       2019-01-06 
NULL    2019-01-07
2       2019-01-08
3       2019-01-03
NULL    2019-01-04 - 2019-01-09
3       2019-01-10

例如2:我需要在NULLID 前后找到2个数据,然后输出将是:

ID      DRange
-------------------------------
1       2019-01-02
1       2019-01-03
NULL    2019-01-04 - 2019-02-01
1       2019-02-02
2       2019-01-06 
NULL    2019-01-07
2       2019-01-08
2       2019-01-09
3       2019-01-02
3       2019-01-03
NULL    2019-01-04 - 2019-01-09
3       2019-01-10

例如3:我需要从NULLID 之前和之后找到3个数据,然后输出将是:

ID      DRange
-------------------------------
1       2019-01-01
1       2019-01-02
1       2019-01-03
NULL    2019-01-04 - 2019-02-01
1       2019-02-02
2       2019-01-06 
NULL    2019-01-07
2       2019-01-08
2       2019-01-09
3       2019-01-02
3       2019-01-03
NULL    2019-01-04 - 2019-01-09
3       2019-01-10

展开
收起
心有灵_夕 2019-12-10 17:25:30 598 0
0 条回答
写回答
取消 提交回答
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
重新定义计算的边界 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载