Подтвердить что ты не робот

Получить последний понедельник - воскресные даты: есть ли лучший способ?

Я готовлю запрос для 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'));

Это примерно в миллион раз больше читаемо. Спасибо.

4b9b3361

Ответ 1

вы можете использовать strtotime для таких проблем с датой

echo strtotime("last Monday");

Ответ 2

(дополнение к marvin и Stomped) Также вы можете использовать его таким образом

echo date('Y-m-d',strtotime('-1 Monday')); //last Monday
echo date('Y-m-d',strtotime('-2 Monday')); //two Mondays ago
echo date('Y-m-d',strtotime('+1 Monday')); //next Monday

Ответ 3

Ответ Марвина очень изящный, хотя, если вы действительно хотели пойти на производительность, вы могли бы сделать это с небольшой арифметикой. Вы можете получить формулу/метод для преобразования произвольной даты в "дни с некоторой начальной точки" (возможно, 01.01.0000), а затем остальная часть операций будет легкой с этим. Получение дня недели от такого числа так же просто, как вычитание и получение остатка от деления.

Собственно, PHP имел класс Date в своей библиотеке PEAR, который выполнял именно это.

Ответ 4

strtotime("previous week Monday")

Понедельник предыдущей недели.

Ответ 5

Я должен указать всем читателям, что есть большая проблема с ответом Марвина

Вот уловка Функция "последний понедельник" вернет дату "последний" понедельник. Это будет объяснено так, если сегодня понедельник, то он вернет дату "ПОСЛЕДНИЙ НЕДЕЛЯ" в понедельник, однако если сегодня не понедельник, он вернется "НА ЭТОЙ НЕДЕЛЕ" понедельник Вопрос заключается в просьбе вернуть "последнюю неделю" в понедельник. Поэтому результат будет неправильным, если сегодня не понедельник. Я решил проблему и обернул мой помощник по дате времени Это будет только одна строка после того, как вы включите "ВКЛЮЧИТЬ" класс

$lastWeekMonday = Model_DTHpr:: getLastWeekMonday();

Проверить здесь

https://github.com/normandqq/Date-Time-Helper