Mysql中TO_DAYS函数 查询最近7天、30天、每天、昨天、上个月的记录 - php

35 篇文章 4 订阅

SQL博大精深

TO_DAYS函数 返回一个天数! 啊哈?什么天数? 从年份0开始的天数 

比如:

mysql> SELECT TO_DAYS(‘1997-10-07′); 

结果  729669
就是从0年开始 到1997年10月7号之间的天数

理解这个之后那么一切就变得拉么简单!有一张表!lito表 有一个字段 create_time  类型 datetime  

如果要查询当前表中昨天的数据那么

select * from lito where to_days(now())-to_days(create_time)<1

前天的?那就是

select * from lito where to_days(now())-to_days(create_time)<2 and to_days(now())-to_days(create_time)>1

一些变量说明:


add_time为插入的时间
to_days是sql函数,返回的是个天数
data()函数返回日期或日期/时间表达式的日期部分
data_sub(date,INTERVAL expr type)给指定的日期减去多少天
curdate()函数返回当前的日期 y-m-d
data_format 用于以不同的格式显示日期/时间数据
period_diff(p1,p2)返回周期P1和P2之间的月数。 P1和P2格式为YYMM或YYYYMM。注意周期参数 P1 和 P2 都不是日期值


1、查询今天的所有记录:
    (1)add_time字段,该字段为int(5)类型的
     

   select * from `article` where to_days(date_format(from_UNIXTIME(`add_time`),'%Y-%m-%d')) = to_days(now());


    (2)add_time字段是DATETIME类型或者TIMESTAMP类型的
       

 select * from `article` where to_days(`add_time`) = to_days(now());


2、查询昨天的所有记录:

    select * from `article` where to_days(now()) <= 1 + to_days(`add_time`);


3、查询近7天的信息记录:
    

select * from `article` where date_sub(curdate(), INTERVAL 7 DAY) <= date(`add_time`);


4、查询近30天的信息记录:
    

select * from `article` where date_sub(curdate(), INTERVAL 30 DAY) <= date(`add_time`);


5、查询本月的记录:
    

select * from `article` where date_format(`add_time`, ‘%Y%m') = date_format(curdate() , ‘%Y%m');


6、查询上一个月的记录:
    

select * from `article` where period_diff(date_format(now() , ‘%Y%m') , date_format(`add_time`, ‘%Y%m')) =1;


 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安果移不动

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值