mysql中根据当前日期计算周一和周日,存在的问题

在数据统计分析的时候,有时候需要计算本周的一些数据情况,比如本周的访问情况,已知条件是当前日期curdate(), 那么如果需要计算本周的访问情况的话,那么就需要计算本周的周一的日期,本周的周日的日期,计算方法如下:

select subdate(curdate(),date_format(curdate(),'%w')-1) #//获取当前日期在本周的周一
select subdate(curdate(),date_format(curdate(),'%w')-2) #//获取当前日期在本周的周二
select subdate(curdate(),date_format(curdate(),'%w')-7) #//获取当前日期在本周的周日

#2018-02-01 是星期四
select subdate(str_to_date('2018-02-01','%Y-%m-%d'),date_format(str_to_date('2018-02-01','%Y-%m-%d'),'%w')-1) # 2018-01-29 正确
select subdate(str_to_date('2018-02-01','%Y-%m-%d'),date_format(str_to_date('2018-02-01','%Y-%m-%d'),'%w')-7) #2018-02-04正确
select subdate(str_to_date('2018-01-29','%Y-%m-%d'),date_format(str_to_date('2018-01-29','%Y-%m-%d'),'%w')-1) # 2018-01-29 正确

比如:当前日期是2018-02-01 本星期的星期四,那么计算本周的周一日期是:2018-01-29,本周的周日日期是:2018-02-04 这种情况下计算是正确的。


但是当前日勤是周日,我们来计算本周的周一和周日,就会存在问题了:

我们使用2018-02-04 是星期天来计算本周的周一和周日,结果如下:

#2018-02-04 是星期天

=================================================================================================
#2018-02-05 错误,正确应该是 2018-01-28
select subdate(str_to_date('2018-02-04','%Y-%m-%d'),date_format(str_to_date('2018-02-04','%Y-%m-%d'),'%w')-1) #2018-02-05 错误
select subdate(str_to_date('2018-02-04','%Y-%m-%d'),date_format(str_to_date('2018-02-04','%Y-%m-%d'),'%w')-7) #2018-02-11 错误

发现计算得来的本周周一是:2018-02-05

本周的周日是:2018-02-11。  已经是下一周的时间了。

我又使用周一到周六每个日期去计算本周的周一和周日,发现计算都是正确的,只有当当前日期是周日的时候,计算出来的本周周一和周日都是下一周的。遇到这种情况,就要看我们的需要了,如果还是希望当前日期是周日,然后计算出来的日期是本周的,那么久需要另外处理了。


坑:当前日期是本周周日,计算本周的周一和周日的日期存在的问题!!!!!!!




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据指定日期计算星期的方法有多种。其一种方法是使用MySQL的date_format函数。通过指定日期和格式化字符串,可以获取日期对应的星期。例如,使用date_format函数并指定格式化字符串'%w',可以获取星期的数字表示,其星期日为0,星期一为1,以此类推。另外,使用格式化字符串'%W'可以获取星期的英文全名,例如'Sunday'表示星期日。使用格式化字符串'%v'可以获取星期的数字表示,其星期一为1,星期日为7。使用格式化字符串'%V'可以获取星期的数字表示,其星期日为1,星期一为2,以此类推。\[3\] 另外,还可以使用MySQL的week函数来计算星期。week函数的第一个参数是日期,第二个参数是星期的起始日,可以是0、1或2,分别表示星期日、星期一和星期一。week函数返回的是日期所在年份的第几。\[3\] 综上所述,根据日期计算星期的方法有多种,可以根据具体需求选择合适的方法。 #### 引用[.reference_title] - *1* *2* *3* [【mysql】获取指定日期是当年第几,指定日期所在的开始和结束日期](https://blog.csdn.net/weixin_42596335/article/details/125470433)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值