微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 获取最后一个星期一 – 星期日的日期:有更好的方法吗?

我正在准备一个关于MysqL查询,以便从上周获得记录,但是我必须将周作为周一至周日.我原来这样做:
WHERE YEARWEEK(contactDate) = YEARWEEK(DATE_SUB(CURDATE(),INTERVAL 7 DAY))

发现MysqL将星期几到星期一对待.所以我正在解析获得开始& PHP结束日期如下:

$i = 0; 
while(date('D',mktime(0,date('m'),date('d')-$i,date('y'))) != "Mon") { 
  $i++; 
}

$start_date = date('Y-n-j',date('d')-($i+7),date('y')));
$end_date  = date('Y-n-j',date('d')-($i+1),date('y')));

这工作 – 它获得当周的星期一(向后走,直到星期一被击中),然后根据该日期计算前一周的日期.

我的问题是:有更好的方法吗?只是似乎马虎,我期望有人可以给我一个更干净的方式来做 – 或者也许不是因为我需要星期一 – 星期几星期.

编辑

显然,有:

$start = date('Y-m-d',strtotime('last monday -7 days'));
$end   = date('Y-m-d',strtotime('last monday -1 days'));

这大概是百万倍的可读性.谢谢.

您可以使用 strtotime这种日期问题
echo strtotime("last Monday");

原文地址:https://www.jb51.cc/php/139944.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐