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天。
MySQL查询策略:获取近7天数据(含/不含当天),
本文介绍了如何使用MySQL查询语句获取近7天的数据,包括含当天时间的和不含当天时间的两种情况,通过CURDATE()和INTERVAL操作实现日期范围筛选。
1084

被折叠的 条评论
为什么被折叠?



