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

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

简单了写了下sql

SELECT

WEEK (  date  )

SUM  (  sale  )

FROM

GROUP BY

WEEK(  date  );

函数

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

去查询了一下手册,看到这个 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
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值