mysql 查询日期间隔方法

  MySQL中查询一定时间间隔内的数据的方法比较常用,可以使用TO_DAYS、DATE_SUB等函数来实现。

TO_DAYS函数的作用是返回指定日期从0年开始计算的天数。

DATE_SUB函数的作用是通过指定日期减去指定间隔时间。

从而可以实现今天、昨天、最近7天(一周)、最近30天(1个月)、上个月等等查询方法。例子如下:

  

1、今天

SELECT * FROM t1 WHERE TO_DAYS(adddate) = TO_DAYS(CURDATE());

 

2、昨天

SELECT * FROM t1 WHERE TO_DAYS(CURDATE()) - TO_DAYS(adddate) = 1;

 

3、最近7天

SELECT * FROM t1 WHERE adddate >= DATE_SUB(CURDATE(),INTERVAL 7 DAY);

 

4、最近30天

SELECT * FROM t1 WHERE adddate >= DATE_SUB(CURDATE(),INTERVAL 30 DAY);

 

5、上个月

SELECT * FROM t1 WHERE DATE_FORMAT(adddate,'%Y-%m') = DATE_FORMAT(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m');

 

实列:

1.

超过30天的查询

$sql = "SELECT proid,extitle,handtime FROM process INNER JOIN example ON process.exid=example.exid  WHERE status=0 AND  handtime < DATE_SUB(CURDATE(),INTERVAL 30 DAY);";    

2.

select from TABLENAME  where Date >=DATE_FORMAT(DATE_ADD(now() ,INTERVAL 1 day),'%Y-%m-%d'and Date< DATE_FORMAT(DATE_ADD(now() ,INTERVAL 2 day),'%Y-%m-%d');

3.

1.利用To_Days函数;

select to_days(now())-to_days('时间字段') ;

2.利用DateDiff函数;

select datediff(now(),'时间字段') ;

案例:

参数1-参数2等于间隔天数

select (datediff(curdate(), date(colunm_name1))- (select colunm_name2 from table_name2)) as o from table_name1 ;

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值