在mysql中,如果要查询的表中只有日期字段,但是业务需求要按照周分组,排序的话,mysql提供了多种方法;

1。date_format

DATE_FORMAT(date, format) 函数根据format字符串格式化date值。

这里可以使用 date_format(date,"%Y-%U")将日期格式化为year-week的方式(注意大小写,Y、U以及更多格式化支持的字符串可以百度或者参考下方文章链接),

然后在分组排序就很简单了,不过这里有一个问题,就是标题所示,跨年使用这种方式;

在mysql中执行下列语句:

select date_format("2017-12-31","%Y-%U"),date_format("2018-1-1","%Y-%U");

结果显示如下

2245972d4f3e645550b479018b7c706c.png

%U代表的是第0周开始的,使用星期天作为一周的第一天,当遇到本年的第一个星期天时,就是第 1 周了,今年第一个星期天之前的天数就当做今年的第0周

当遇到同一周跨年的时候,12月份的算作去年的最后一周,1月份的算作今天的第0周就不对了,

如2017-12-31和2018-01-01是在同一周(周日-周六为同一周),所以这种方法有误

可以用格式符%X-%V代替

select date_format("2017-12-31","%X-%V"),date_format("2018-1-1","%X-%V");

结果显示如下

30447c74f4cca642f2a4c787304441f2.png

%V 与 %U 一样的地方就是也是使用周日作为一周的开始,并且也是遇到第一个周日开始算作是第一周,但是这两个对这个下一年第一个周日之前的这几天处理不一样,%U是把下一年之前的几天算作第0周而%V是把下一年之前的几天算作上一年的最后一周,所以使用%X-%V这样的格式符就能解决问题

2.YEARWEEK

.MySQL 的 YEARWEEK 是获取年份和周数的一个函数,函数形式为 YEARWEEK(date[,mode])

mode的值从0-7,分别指示每周的第一天是周几,具体可以百度或者参考下方链接文章

select YEARWEEK("2017-12-31",),YEARWEEK("2018-1-1");

结果显示如下

3523ed214b84b45b82abb7f8038c1791.png

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐