mysql 周_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");

结果显示如下

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

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值