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

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
赞 (2) 分享
声明:原创文章,欢迎转载,请以 超链接 的形式注明 作者标题原始出处查看许可协议
标题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. 是的,刚开始折腾一会儿,现在也慢慢静下来了

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