mysql查询前七天和前30天每一天的日期,一年的每个月

小编有这样一个需求,当前时间是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

妥了,你也可以试一试,百分百好使。希望对你们有用

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值