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");

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...