您的位置:首页 > 数据库 > MySQL

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

2017-04-13 16:40 627 查看
-- 当天

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

-- 本周

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;


查询上个月的数据

<
4000
span style="font-family:'Microsoft YaHei';font-size:14px;">
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();
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐