mySql 查询当天、本周、最近7天、本月、最近30天的语句

-- 当天

SELECT * FROM  表名 WHERE where to_days(时间字段名) = to_days(now());

-- 昨日

SELECT column_name(s) FROM 表名     WHERE DATE_FORMAT(时间字段,'%Y-%m-%d') = DATE_FORMAT(CURDATE()-1,'%Y-%m-%d');

SELECT column_name(s) FROM 表名 WHERE DATE(时间字段) =DATE(CURDATE()-1);

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

-- 本周

SELECT * FROM  表名 WHERE YEARWEEK(date_format(时间字段,'%Y-%m-%d')) = YEARWEEK(now());

-- 最近7天

SELECT * FROM  表名  where date_sub(curdate(), INTERVAL 7 DAY) <= date (时间字段);

-- 本月

SELECT * FROM  表名 where date_format(时间字段, '%Y%m') = date_format(curdate() , '%Y%m');

-- 最近30天

SELECT * FROM  表名 WHERE date_sub(curdate(), INTERVAL 30 DAY) <= date(时间字段);

-- 上一月

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

SELECT * FROM 表名 WHERE QUARTER(create_date)=QUARTER(now()); 

 

查询上季度数据

SELECT * FROM  表名 WHERE QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));

查询本年数据

SELECT * FROM  表名 WHERE YEAR(create_date)=YEAR(NOW());

查询上年数据

SELECT * FROM  表名 WHERE year(create_date)=year(date_sub(now(),interval 1 year));

查询上周的数据

 

SELECT * FROM  表名 WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now())-1;

查询上个月的数据

复制代码

SELECT * FROM  表名 WHERE date_format(submittime,'%Y-%m')=date_format(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m')

SELECT * FROM  表名 WHERE DATE_FORMAT(pudate,'%Y%m') = DATE_FORMAT(CURDATE(),'%Y%m') ; 
SELECT * FROM  表名 WHERE WEEKOFYEAR(FROM_UNIXTIME(pudate,'%y-%m-%d')) = WEEKOFYEAR(now()) 

SELECT * FROM  表名 WHERE MONTH(FROM_UNIXTIME(pudate,'%y-%m-%d')) = MONTH(now()) 

SELECT * FROM  表名 WHERE YEAR(FROM_UNIXTIME(pudate,'%y-%m-%d')) = YEAR(now()) and MONTH(FROM_UNIXTIME(pudate,'%y-%m-%d')) = MONTH(now()) 

SELECT * FROM  表名 WHERE pudate between  上月最后一天  and 下月第一天 

复制代码

 

查询距离当前现在6个月的数据

 

SELECT * FROM  表名 WHERE submittime between date_sub(now(),interval 6 month) and now();

 

 

 

 

 

 

 

 

你可能感兴趣的:(mysql)