在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");
结果显示如下
%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");
结果显示如下
%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");
结果显示如下