MySQL的跨年周统计问题

在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");

结果显示如下 输入图片说明

参考链接 https://stackoverflow.com/questions/1736010/how-to-group-by-week-in-mysql http://blog.csdn.net/lifuxiangcaohui/article/details/50953018 http://blog.csdn.net/u010004317/article/details/54426836

猜你喜欢

转载自my.oschina.net/u/1417838/blog/1620169
今日推荐