当寻求为 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”之间的一系列日期。子查询创建一个从 0 到 9 的数字表,然后使用 adddate() 函数使用这些数字来构造日期。最后的 where 子句过滤结果,只包含指定范围内的日期。
通过使用此方法,您可以高效地生成一系列日期,而不需要临时表或变量,适合以下情况:权限受限。
以上是如何在没有临时表或变量的情况下在 MySQL 中生成日期系列?的详细内容。更多信息请关注PHP中文网其他相关文章!