小编有这样一个需求,当前时间是2020-9-10,我要查询现在到七天前每天的日期,如下:
小编查询了很久,发现网上只有前三十天的每天的日期,所以小编根据他们的改了一些。
-- 最近30天
select date_add(curdate(), interval(cast(help_topic_id as signed integer) - 30) day) day
from mysql.help_topic
where help_topic_id <= day(last_day(curdate()))
order by help_topic_id
-- 最近7天
select date_add(curdate(), interval(cast(help_topic_id as signed integer) - 6) day) day
from mysql.help_topic
where help_topic_id <= 6
order by help_topic_id
-- 一年内的每个月
select mid(date_add(curdate(), interval(cast(help_topic_id as signed integer) - 11) day) ,1,7) day
from mysql.help_topic
where help_topic_id <= 11
order by help_topic_id
如果你要改编的话,你需要了解data_add,interval函数,复合函数组合,发现真的是无敌,你们可以看看这篇文章。
https://blog.csdn.net/reee112/article/details/83818526
这边文章写得很详细,小编也是看了这个函数的意思才弄出来的,如果不对的话请指正。
上面的那种方法使用mysql.help_topic涉及查询权限的问题,如果你遇到了这个问题可以换一种方式,就是上面sql的改版。
(1)、先建一张数字表,存放0-31的数字即可,比较一个月最长也就31天,如果有其他需求也可也加这表
CREATE TABLE num (i INT);
INSERT INTO num (i) VALUES (0),(1),(2),(3),(4),(5),(6),(7),(8),(9),(10),(11),(12),(13),(14),(15),(16),(17),(18),(19),(20),(21),(22),(23),(24),(25),(26),(27),(28),(29),(30),(31),(32),(33),(34),(35),(36),(37),(38),(39),(40);
(2)改造上面的sql
-- 最近30天
select date_add(curdate(), interval(cast(i as signed integer) - 30) day) day
from num
where i <= day(last_day(curdate()))
order by i
-- 最近7天
select date_add(curdate(), interval(cast(i as signed integer) - 6) day) day
from num
where i <= 6
order by i
-- 一年每个月
select mid(date_add(curdate(), interval(cast(i as signed integer) - 11) MONTH),1,7) day
from num
where i <= 11
order by i
妥了,你也可以试一试,百分百好使。希望对你们有用