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

本文探讨了在使用SQL计算当前周的起始和结束日期时遇到的问题,特别是在当前日期为周日的情况。通过示例说明了计算逻辑,并指出了可能出现的误差。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在数据统计分析的时候,有时候需要计算本周的一些数据情况,比如本周的访问情况,已知条件是当前日期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。  已经是下一周的时间了。

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


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




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值