Я готовлю запрос для mySQL, чтобы захватить запись с предыдущей недели, но я должен рассматривать недели как понедельник - воскресенье. Я изначально сделал это:
WHERE YEARWEEK(contactDate) = YEARWEEK(DATE_SUB(CURDATE(),INTERVAL 7 DAY))
чтобы узнать, что mySQL рассматривает недели как воскресенье - понедельник. Поэтому вместо этого я разбираю дату начала и окончания php следующим образом:
$i = 0;
while(date('D',mktime(0,0,0,date('m'), date('d')-$i, date('y'))) != "Mon") {
$i++;
}
$start_date = date('Y-n-j', mktime(0,0,0,date('m'), date('d')-($i+7), date('y')));
$end_date = date('Y-n-j', mktime(0,0,0,date('m'), 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'));
Это примерно в миллион раз больше читаемо. Спасибо.