mysql yearweek 日期不准_Mysql 中,WEEK 与YEARWEEK函数的参数问题

今天碰到一个问题,说在 mysql 里面, 要按周统计, 周的计算,是从 每周一到周日。

简单了写了下

SELECT

WEEK (  date  )

SUM  (  sale  )

FROM

GROUP BY

WEEK(  date  );

发现 默认情况下, 这个 WEEK ( 日期 )  是 每把周日,作为一周的开始。

去查询了一下手册,看到这个 WEEK 函数, 还可以额外再跟一个 参数。

这个参数决定了, 使用星期几,来作为 一周的开始。

以及用什么样的逻辑,来计算 一年里面, 第一周的计算方式。

这个参数的描述如下:

参数值

每周第一天

是星期几

返回值

范围

第一周是怎么计算的?

0

星期天

0-53

遇到本年的第一个星期天开始,是第一周。

前面的计算为第0周。

1

星期一

0-53

假如第一周能超过3天,那么计算为本年的第一周。否则为第0周

可以理解为

如果1月1号~4号是星期一,那么本年第一周开始。(之前的是第零周)

如果1月5号以后是星期一,那么现在开始,是本年的第二周了,之前的是第一周。

2

星期天

1-53

遇到本年的第一个星期天开始,是第一周。

前面的计算为上年度的第5x周。

3

星期一

1-53

假如第一周能超过3天,那么计算为本年的第一周。否则为上年度的第5x周。

可以理解为

如果1月1号~4号是星期一,那么本年第一周开始。(之前的是第5x周)

如果1月5号以后是星期一,那么现在开始,是本年的第二周了,之前的是第一周。

4

星期天

0-53

假如第一周能超过3天,那么计算为本年的第一周。否则为第0周

可以理解为

如果1月1号~4号是星期天,那么本年第一周开始。(之前的是第零周)

如果1月5号以后是星期天,那么现在开始,是本年的第二周了,之前的是第一周。

5

星期一

0-53

遇到本年的第一个星期一开始,是第一周。

前面的计算为第0周。

6

星期天

1-53

假如第一周能超过3天,那么计算为本年的第一周。否则为上年度的第5x周。

可以理解为

如果1月1号~4号是星期天,那么本年第一周开始。(之前的是第5x周)

如果1月5号以后是星期天,那么现在开始,是本年的第二周了,之前的是第一周。

7

星期一

1-53

遇到本年的第一个星期一开始,是第一周。

前面的计算为上年度的第5x周。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值