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周。

相关文章
相关标签/搜索