我爱自学

 找回密码
 会员注册

QQ登录

只需一步,快速开始

Mysql datetime、时间戳按月、周、日分组查询

Mysql在数据存储查询上使用较多,记录数据时一般有时间字段。时间字段有日期的datetime类型,也有的是时间戳的整数类型。如何通过时间字段,按月、周、日查询数据呢!
最近入手学习echarts图表插件,想要将mysql数据库中的数据按月分组查询出来。开始,想的方式是,新增一个字段存储月份,然后将该字段查询出来。


但是这种方式,一想都觉得太麻烦了,应该是可以通过时间戳转换为月份吧!网络上搜索了资料,mysql确实支持时间戳按月分组查询数据。


如果时间字段为时间戳(timestamp)或int表示的时间戳(字段是 create_time):


按月查询

SELECT FROM_UNIXTIME(create_time,'%Y%m') months,COUNT(id) count FROM  inform where smalltype='12_1' GROUP BY months
order by count desc


查询效果:

Mysql datetime、时间戳按月、周、日分组查询

Mysql datetime、时间戳按月、周、日分组查询


按周查询

SELECT FROM_UNIXTIME(create_time,'%Y%u') weeks,COUNT(id) count FROM  where smalltype='12_1' GROUP BY weeks order by count desc

按天查询

SELECT FROM_UNIXTIME(create_time,'%Y%m%d') days,COUNT(id) count FROM  where smalltype='12_1' GROUP BY days order by count desc



如果时间字段类型为date或datetime,该如何分组查询呢:

按周查询

SELECT DATE_FORMAT(create_time,'%Y%u') weeks,COUNT(id) count FROM  inform where smalltype ='12_1' GROUP BY weeks order by count desc

按天查询
SELECT DATE_FORMAT(created_at,'%Y-%m-%d') days,COUNT(id) count FROM  inform where smalltype ='12_1'  GROUP BY days order by count desc

按月查询
SELECT DATE_FORMAT(create_time,'%Y%m') months,COUNT(id) count FROM  inform where smalltype ='12_1'  GROUP BY months order by count desc

点击阅读更多内容!
如果您觉得文章内容帮助到了您,不妨点点感兴趣的广告。感谢您的支持!

微信扫一扫打赏

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

手机版|小黑屋|我爱自学 ( 蜀ICP备19015358号-3 )

GMT+8, 2024-4-25 10:16 , Processed in 0.065733 second(s), 56 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

本站大部分教程是网站原创教程,一部分教程为我爱自学(http://www.5izixue.com)编辑收集整理。

如果您需要转载我爱自学网站教程,请注明“资料来源:我爱自学(5izixue)”字样并注明本站网址。

编辑收集整理的教程版权归原作者所有,本站只提供网友交流学习使用,请勿用于商业用途,如果该文章有任何侵犯您权益的地方,请联系我们(569705694@qq.com),我们将在第一时间进行处理!谢谢您的支持!

快速回复 返回顶部 返回列表