DB2请教取任何两个时间段内的所有年月的SQL语句如何实现 比如 20050903 -- 20060201,得到 200509 200510

比如20050903--20060201,得到200509200510200511200512200601200602... 比如 20050903 -- 20060201,得到 200509 200510 200511 200512 200601 200602 展开
 我来答
liuyx_know
2010-09-01 · TA获得超过425个赞
知道小有建树答主
回答量:506
采纳率:100%
帮助的人:406万
展开全部
其实很多需求没有必要老想着用一个语句搞掂,可以试试用存储过程或者函数完成。假如你真的不想用存储过程或者函数,你可以参照下面的语句实现你的要求:
WITH TEMP1(COL1,COL2) AS
(
VALUES (DATE('2005-09-03'), DATE('2005-09-03') + 1 MONTHS)
UNION ALL
SELECT COL1 + 1 MONTHS, COL2 + 1 MONTHS
FROM TEMP1
WHERE COL1 + 1 MONTHS <= DATE('2006-02-01')
)
SELECT
YEAR(COL1) * 100 + MONTH(COL1) AS MONBEGIN,
YEAR(COL2) * 100 + MONTH(COL2) AS MONEND
FROM TEMP1

你只要将语句里面的日期替换一下就能实现你的要求。 语句执行后的结果是这样:
MONBEGIN MONEND
200509 200510
200510 200511
200511 200512
200512 200601
200601 200602
nihaozhengjun
2010-09-01 · TA获得超过138个赞
知道答主
回答量:110
采纳率:0%
帮助的人:110万
展开全部
我这里有个解决方案不知道适合你不,比如rq是一个关于日期的字段select replace(str(year(rq))+str(month(rq)),' ','')from table 就基本上能实现你的要求,不过有点遗憾的是,他9月就是一个9,没有09,这个跟datatima型有关吧,我是在sql查询分析器上测试的,你自己斟酌一下吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友91f49c4
2010-09-06 · TA获得超过1176个赞
知道小有建树答主
回答量:1683
采纳率:0%
帮助的人:668万
展开全部
存储过程
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式