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

Кемеровские программисты php общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Получите даты последнего понедельника – воскресенья: есть ли лучший способ?

Сообщение Anonymous »

Я готовлю запрос для 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'));
Это примерно в миллион раз читабельнее. Спасибо.

Подробнее здесь: https://stackoverflow.com/questions/241 ... better-way
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Php»