首页 > 数据库 > mysql教程 > 如何在不使用临时表或变量的情况下在 MySQL 中生成一系列不重复的日期?

如何在不使用临时表或变量的情况下在 MySQL 中生成一系列不重复的日期?

Susan Sarandon
发布: 2024-12-08 10:21:11
原创
1033 人浏览过

How Can I Generate a Series of Non-Duplicate Dates in MySQL Without Using Temporary Tables or Variables?

生成一系列日期(非重复方法)

创建特定范围内的一系列日期是在以下环境中遇到的常见任务各种编程应用程序。 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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板