生成一系列日期(非重复方法)
创建特定范围内的一系列日期是在以下环境中遇到的常见任务各种编程应用程序。 MySQL 提供了多种方法来实现此目的。
一种有效的解决方案,特别是在面临禁止临时表创建和变量设置等限制时,是利用自连接查询。此方法生成指定时间范围内的日期列表,如以下代码片段所示:
select * from (select adddate('1970-01-01',t4*10000 + t3*1000 + t2*100 + t1*10 + t0) gen_date from (select 0 t0 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t0, (select 0 t1 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t1, (select 0 t2 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t2, (select 0 t3 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t3, (select 0 t4 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t4) v where gen_date between '2017-01-01' and '2017-12-31'
此查询生成“2017-01-01”和“2017-12”之间的一系列日期-31' 通过使用 adddate() 函数和表示日、月和年的各种子查询来操作日期值。
这种方法提供了一个简洁的方法生成一系列日期的有效方法,特别是在临时表创建或变量设置不可行的情况下。
以上是如何在不使用临时表或变量的情况下在 MySQL 中生成一系列不重复的日期?的详细内容。更多信息请关注PHP中文网其他相关文章!