mysql 查當天、本週,本月、上月資料

隱德萊希發表於2024-01-11

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 協議》,轉載必須註明作者和本文連結

相關文章