我正在准备一个关于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这种日期问题
原文链接:https://www.f2er.com/php/139944.htmlecho strtotime("last Monday");