旗下导航:搜·么
当前位置:网站首页 > MySQL教程 > 正文

MySQL按时候统计数据的要领引见(代码示例)【MySQL教程】,mysql,数据

作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:42评论:0


导读:本篇文章给人人带来的内容是关于MySQL按时候统计数据的要领引见(代码示例),有肯定的参考价值,有须要的朋侪能够参考一下,愿望对你有所协助。在做数据库的统计时,经常会须要依...
本篇文章给人人带来的内容是关于MySQL按时候统计数据的要领引见(代码示例),有肯定的参考价值,有须要的朋侪能够参考一下,愿望对你有所协助。

在做数据库的统计时,经常会须要依据年、月、日来统计数据,然后合营echarts来制造可视化结果。

  • 数据库:MySQL(引荐教程:MySQL教程)

思绪

  • 根据时候维度举行统计的条件是须要数据库中有保存时候信息,发起是运用MySQL自带的datetime范例来纪录时候。

`timestamp` datetime DEFAULT NULL,
  • 在MySQL中关于时候日期的处置惩罚的函数主假如DATE_FORMAT(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 位

:当涉及到按日统计是,须要运用%j,而假如运用%d, %e, %w的话,那末差别月份/周里的雷同值会统计在一起。

  • 涉及到猎取当前时候,则能够经由过程now()或许sysdate()来猎取。

SELECT SYSDATE() FROM DUAL;
SELECT NOW() FROM DUAL;
  • 根据现实需求运用group by查询即可。

结论

需统计的表构造以下:

CREATE TABLE `apilog` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(64) DEFAULT NULL,
  `action` varchar(64) DEFAULT NULL,
  `params` text,
  `result` text,
  `timestamp` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
)
  • 统计时候范围内差别分类action的数目

    # 当日
    SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%j') = DATE_FORMAT(now(),'%j') ORDER BY count desc;
    # 当周
    SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%u') = DATE_FORMAT(now(),'%u') ORDER BY count desc;
    # 当月
    SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%m') = DATE_FORMAT(now(),'%m') ORDER BY count desc;
    # 昔时
    SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%Y') = DATE_FORMAT(now(),'%Y') ORDER BY count desc;
  • 统计某分类action的时候维度数目

    # 按日
    SELECT action, DATE_FORMAT(`timestamp`,'%j'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%j')
    # 按周
    SELECT action, DATE_FORMAT(`timestamp`,'%u'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%u')
    # 按月
    SELECT action, DATE_FORMAT(`timestamp`,'%m'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%m')
    # 按年
    SELECT action, DATE_FORMAT(`timestamp`,'%Y'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%Y')

    同时按action和时候维度统计

    # 按日
    SELECT action, DATE_FORMAT(`timestamp`,'%j'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%j')
    # 按周
    SELECT action, DATE_FORMAT(`timestamp`,'%u'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%u')
    # 按月
    SELECT action, DATE_FORMAT(`timestamp`,'%m'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%m')
    # 按年
    SELECT action, DATE_FORMAT(`timestamp`,'%Y'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%Y')

以上就是比较经常使用的时候统计了,更多的时候维度,能够参考上面的参数表相似处置惩罚即可。

以上就是MySQL按时候统计数据的要领引见(代码示例)的细致内容,更多请关注ki4网别的相干文章!

标签:mysql数据


欢迎 发表评论: