我需要知道在(我的)SQL中是否有一种有效的方法来执行在大多数编程语言中类似于for-循环的select语句。最简单的例子是创建一个值为1到100的列。我四处寻找解决方案(我发现最有趣的是一个交叉连接每一个数字,直到目标长度)。最后,我在db中创建了一个名为N(如数学符号)的表,其中包含一个“n”列,值从1百万到1百万。
下面是我需要的一个例子:
select .....
cross join
(
select n,str_to_date(period_add(date_format(CURDATE(),'%Y%m'),n),'%Y%m') as 'date' from n where n<period_diff(201912,date_format(CURDATE(),'%Y%m'))
)这将返回一个列,其中包含从curdate (恰巧是2017年3月)到2019年12月的所有年/月组合。您可以看到n用作一个“变量”,用于添加月份和计算"for循环的结束条件“。这个效果很好。那么问题是:是否有更优雅的方法来做到这一点?
发布于 2017-03-19 16:26:43
你的方法很好。我可能倾向于:
select date_add(date_add(curdate(), interval 1 - day(curdate()) day), interval n.n month)
from n
where date_add(date_add(curdate(), interval 1 - day(curdate()) day), interval n.n month) <= '2019-12-01'我更喜欢做日期算术,而不是来回地做字符串。
这句话:
date_add(curdate(), interval 1 - day(curdate()) day)只是一个月的第一天。
https://stackoverflow.com/questions/42888982
复制相似问题