MySql按日期时间段进行统计(前一天、本周、某一天、某个时间段)

在mysql数据库中,常常会遇到统计当天的内容。

例如,在user表中,日期字段为:log_time

统计当天

sql语句为:

select * from user where date(log_time) = curdate();    

curdate()表示当天日期

统计前一天

如果表示前一天的数据,则不能使用curdate()-1,因为当日期为月初时,curdate()-1 日期就不是上一个月的月末日期。

例如:今天是6月1日,理论上curdate()-1为5月31日,但是curdate()-1得到不是5月31日,而是6月0日。那么统计前一天的日期就不能使用curdate()-1了,mysql数据库又有一个新方法统计前一天的数据。

统计前一天的日志sql语句:

select * from bean where date(log_time) = date_sub(curdate(),interval 1 day);  

括号中为当天时间的前一天,如果统计前几天就将括号中的’1’改成相应的天数。如果要算月或年,直接将day改为month或year即可

统计本周

要求: 统计从昨天开始统计前7天的日志包括昨天

select * from user where date(log_time) >= date_sub(curdate(),interval 7 day) and date(log_time) <=  date_sub(curdate(),interval 1 day)  

在网上找的使用week统计一周信息,只能统计到5天的信息,不符合要求,所以改用这种方法。

统计某一天

统计历史某一天的日志,将date_sub(curdate(),interval 0 day)函数中的curdate()替换为某一天的日期。比如:要统计2012-05-25日期的信息

date_sub('2012-05-25',interval 0 day)

关于date_sub()函数的例子

今天是2013年5月20日。

date_sub('2012-05-25',interval 1 day) 表示 2012-05-24
date_sub('2012-05-25',interval 0 day) 表示 2012-05-25
date_sub('2012-05-25',interval -1 day) 表示 2012-05-26
date_sub('2012-05-31',interval -1 day) 表示 2012-06-01
date_sub(curdate(),interval 1 day) 表示 2013-05-19
date_sub(curdate(),interval -1 day) 表示 2013-05-21
date_sub(curdate(),interval 1 month) 表示 2013-04-20
date_sub(curdate(),interval -1 month) 表示 2013-06-20
date_sub(curdate(),interval 1 year) 表示 2012-05-20
date_sub(curdate(),interval -1 year) 表示 2014-05-20

按时间段统计

这里要用到DATE_FORMAT函数,这个函数非常万能,如下例:

select * from user where DATE_FORMAT(log_time,'%H') >= '18' and DATE_FORMAT(log_time,'%H') < '19' and DATE_FORMAT(log_time,'%Y')='2014';    

意思不用我说,大家都知道,就是查询所有在18点到19点之间的,并且是2014年的数据。

Date_format可以使用的格式

格式 描述
%a 缩写星期名
%b 缩写月名
%c 月,数值
%D 带有英文前缀的月中的天
%d 月的天,数值(00-31)
%e 月的天,数值(0-31)
%f 微妙
%H 小时 (00-23)
%h 小时 (01-12)
%I 小时 (01-12)
%i 分钟,数值(00-59)
%j 年的天 (001-366)
%k 小时 (0-23)
%l 小时 (1-12)
%M 月名
%m 月,数值(00-12)
%p AM 或 PM
%r 时间,12-小时(hh:mm:ss AM 或 PM)
%S 秒(00-59)
%s 秒(00-59)
%T 时间, 24-小时 (hh:mm:ss)
%U 周 (00-53) 星期日是一周的第一天
%u 周 (00-53) 星期一是一周的第一天
%V 周 (01-53) 星期日是一周的第一天,与 %X 使用
%v 周 (01-53) 星期一是一周的第一天,与 %x 使用
%W 星期名
%w 周的天 (0=星期日, 6=星期六)
%X 年,其中的星期日是周的第一天,4 位,与 %V 使用
%x 年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y 年,4 位
%y 年,2 位
/usr/themes/NexTSun/static/images/yovisun-weixin-share.jpg
赞 (3) 分享
声明:原创文章,欢迎转载,请以 超链接 的形式注明 作者标题原始出处查看许可协议
标题MySql按日期时间段进行统计(前一天、本周、某一天、某个时间段) | 作者:YoviSun
地址http://www.yovisun.com/archive/mysql-date-statistics.html
相关文章:
已有 9 条评论
  1. 蘑菇 蘑菇

    博主文笔很好啊,期待写出更好的文章,以后常来坐坐,学一下

  2. 双语不用教 双语不用教

    博主文章不错,以后常来

  3. 匿名 匿名

    分析的很好,欢迎回访,下次还会来

  4. hang hang

    博主用的是神马主机,速度挺快的

    1. yovisun yovisun

      美国的主机

  5. 匿名 匿名

    没事做,来你博客看看。

  6. 匿名 匿名

    感觉学了蛮多东西,收藏您的博客了。希望您经常更新一些好的文章!希望通过学习,能把我的网站给做上去!

  7. 第七星尘 第七星尘

    这代码高亮插件看起来很清爽啊。不过typecho,我还是不折腾了。对博客的热情已经褪去。

    1. YoviSun YoviSun

      是的,刚开始折腾一会儿,现在也慢慢静下来了

添加新评论
选择表情
手机扫描二维码访问