MySQL查询近7天数据,可根据需求直接改变天数获取相对的数据

MySQL查询近7天数据

No nonsense

(当前SQL可根据需求直接改变天数获取相对的数据)

含当天时间的近7天数据

SELECT * FROM your_table
WHERE create_time>= (CURDATE() - INTERVAL 7 DAY) + INTERVAL 0 SECOND  
AND CURDATE() + INTERVAL 23 HOUR + INTERVAL 59 MINUTE + INTERVAL 59 SECOND

不含当天时间的近7天数据

SELECT * FROM your_table
WHERE create_time>= CURDATE() - INTERVAL 7 DAY
AND create_time<= CURDATE();

解释:

1.SELECT * FROM your_table:要查询的数据表,将your_table替换为实际的表名。
2.WHERE create_time>= (CURDATE() - INTERVAL 7 DAY) + INTERVAL 0 SECOND:

(1) CURDATE()函数表示的是返回当前日期。

(2) INTERVAL 7 DAY表示7天的时间跨度,表示一个时间跨度为7天的间隔,这个间隔可以用于在日期和时间计算中进行加法或减法操作。

(3) (CURDATE() - INTERVAL 7 DAY)计算出7天前的日期。

(4) INTERVAL 0 SECOND表示0秒的时间跨度。

(5) (CURDATE() - INTERVAL 7 DAY) + INTERVAL 0 SECOND得到7天前日期的凌晨时间点。 这样的设定确保查询结果包括了从7天前凌晨开始的数据。

3.(CURDATE() - INTERVAL 7 DAY) + INTERVAL 0 SECOND得到7天前日期的凌晨时间点。 这样的设定确保查询结果包括了从7天前凌晨开始的数据。

(1)CURDATE()函数返回当前日期。

(2)INTERVAL 23 HOUR + INTERVAL 59 MINUTE + INTERVAL 59 SECOND表示一天的最后一秒的时间跨度。

(3)CURDATE() + INTERVAL 23 HOUR + INTERVAL 59 MINUTE + INTERVAL 59 SECOND得到当前日期的当天最后一秒的时间点。 这样的设定确保查询结果包括了截止到当天最后一秒的数据。


总结

1.通过将下界设置为7天前的凌晨时间,并将上界设置为当天最后一秒的时间,这个SQL查询语句可以返回最近7天的数据,包括当天的数据。请注意,日期范围的比较操作符使用的是>=和<=,这样可以确保包含下界和上界的数据。
2.INTERVAL 7 DAY 表示从一个日期或时间点往前或往后移动7天。如果你提供一个具体的日期值,比如2022-01-01,那么将 INTERVAL 7 DAY 加到这个日期上将得到2022-01-08。同样地,从2022-01-08 减去 INTERVAL 7 DAY 将得到2022-01-01,所以,时间跨度为7天,表示从所在的日期或时间点开始,向前推7天,或者向后推7天。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值