mysql 查当天、本周,本月、上月数据

1. 查询当天数据

第一种:数量小的时候用,数据量稍微起来巨慢

select 字段 from 表名 where to_days(时间字段) = to_days(now());

第二种:速度快

select 字段 from 表名 where 时间字段 BETWEEN CONCAT(CURDATE(),' 00:00:00') AND CONCAT(CURDATE(),' 23:59:59');

最好配合复合索引来查,避免全表扫描

2. 查询昨天的数据

SELECT * FROM `day_sell` WHERE TO_DAYS(NOW()) - TO_DAYS(sell_time) <= 1

3. 查询最近 7 天的(包含 7 天总计 7 天)

#7 天的数据

SELECT * FROM `day_sell` WHERE DATE_SUB(CURDATE(),INTERVAL 7 DAY) < DATE(sell_time);

4. 查询本月的数据

SELECT * FROM `day_sell` WHERE DATE_FORMAT(sell_time,'%Y-%m')= DATE_FORMAT(CURDATE(),'%Y-%m')

5. 查询上个月的数据

SELECT * FROM day_sell WHERE PERIOD_DIFF(DATE_FORMAT(NOW(),'%Y%m'),DATE_FORMAT(sell_time,'%Y%m')) = 1;

6. 查询上季度

SELECT * FROM day_sell WHERE QUARTER(sell_time) = QUARTER(DATE_SUB(NOW(),INTERVAL 1 QUARTER));

7. 查询本季度

SELECT * FROM `day_sell` WHERE QUARTER(sell_time) = QUARTER(NOW())

8. 查询今年的数据

SELECT * FROM `day_sell` WHERE YEAR(sell_time) = YEAR(NOW())

9. 计算两个时间间隔 - 天

SELECT DATEDIFF('2020-10-29','2020-10-28') AS days;

10. 按周统计

SELECT DATE_FORMAT(sell_time,'%Y%u') weeks,COUNT(sell_time) COUNT FROM `day_sell` GROUP BY weeks;

11. 按天统计

SELECT DATE_FORMAT(sell_time,'%Y%m%d') days,COUNT(sell_time) COUNT FROM day_sell GROUP BY days;

12. 按月统计

SELECT DATE_FORMAT(sell_time,'%Y%m') months,COUNT(sell_time) COUNT FROM day_sell GROUP BY months;

13. 查询去年

SELECT * FROM day_sell WHERE YEAR(sell_time) = YEAR(DATE_SUB(NOW(),INTERVAL 1 YEAR));

14. 查询近 6 个月的数据

SELECT * FROM day_sell WHERE sell_time BETWEEN DATE_SUB(NOW(),INTERVAL 6 MONTH) AND NOW();
本作品采用《CC 协议》,转载必须注明作者和本文链接
讨论数量: 6

这样子做可能需要注意数据库的时区和代码文件的时区不一致,导致查询数据出现偏差。🤣

1年前 评论
隐德莱希 (楼主) 1年前
隐德莱希 (楼主) 1年前
sinmu (作者) 1年前

mysql:好好好,这么玩是吧,不管我的死活是吧~

1年前 评论
隐德莱希 (楼主) 1年前