mysql 查询当天、本周,本月,上一个月的数据

分类:计算机 | 数据库 | MySQL | 综合 1067
更新:2021-02-24 11:53:08
编辑

转载地址

https://www.jb51.net/article/133943.htm

今天

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

昨天

SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1

近7天

SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(时间字段名)

近30天

SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(时间字段名)

本月

SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )

上一月

SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1

查询本季度数据

select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(now()) and YEAR(create_date)=YEAR(NOW());

注意:本季度同时也是本年,所以也要判断时间是不是本年的,然后再去判断是不是本季度

说明:1-3月是第一季度,4-6月是第二季度,7-9月是第三季度,10-12月是第四季度。

QUARTER()函数返回给定日期值(1到4之间的数字)的一年中的季度。

  1. 1月至3月返回1
  2. 4月至6月返回2
  3. 7月至9月返回3
  4. 10月至12月返回4

示例:

SELECT QUARTER("2017-06-15"); 

返回的是2

查询上季度数据

select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));

查询本年数据

select * from `ht_invoice_information` where YEAR(create_date)=YEAR(NOW());

查询上一年数据

select * from `ht_invoice_information` where year(create_date)=year(date_sub(now(),interval 1 year));