Ben mySQL önceki haftaya rekor kapmak için bir sorgu hazırlanıyor, ama ben Pazartesi olarak hafta davranmak zorunda - Pazar. Ben aslında bu yapmıştı:
WHERE YEARWEEK(contactDate) = YEARWEEK(DATE_SUB(CURDATE(),INTERVAL 7 DAY))
Pazartesi - mySQL Pazar olarak hafta davranır keşfetmek için. Peki yerine ben başlamak ve alıyorum ayrıştırma ediyorum Böyle php bitiş tarihleri:
$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')));
Bu çalışır - bu o tarih esas hafta önceki tarihleri hesaplar (Bir Pazartesi isabet kadar geriye yürüme) Pazartesi için geçerli haftaki tarihini alır.
Benim soru: Bunu yapmak için daha iyi bir yolu var mı? Sadece özensiz görünüyor, ve ben orada birisi bana bir süpürge yapmak için yol verebilir bekliyoruz - Ben Pazartesi gerekir, çünkü ya da belki değil - Pazar haftalar.
Edit
Görünüşe göre, var:
$start = date('Y-m-d',strtotime('last monday -7 days'));
$end = date('Y-m-d',strtotime('last monday -1 days'));
Bu yaklaşık bir milyon kat daha okunabilir. Teşekkür ederim.