Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Mysql SELECT - Sortowanie uwzględniające dzień tygodnia.
Forum PHP.pl > Forum > PHP
denis94
Witam.
Borykam się z problemem odpowiedniego sortowania pobranych wyników z bazy danych.
W tabeli mam rekordy które przechowują wydarzenia w mieście. Struktura to: id, nazwa, dzien, godzina
(gdzie poniedziałek = 1 a niedziela = 7)

Chciałbym aby sortowanie było zależne od dnia tygodnia który jest aktualnie.
Funkcją date("w") pobieram aktualny dzień tygdnia.

Tak formułuje zapytanie: SELECT * FROM wydarzenia WHERE dzien>=$dzien_aktualny ORDER BY dzien ASC LIMIT 1

Problem jest taki, że jeżeli dziś jest środa, to zapytanie wyszuka najbliższe wydarzenie od dziś do niedzieli. Muszę zrobić za pomocą jednego zapytania w taki sposób, że jeżeli od dziś do niedzieli nie ma żadnego wydarzenia to wyszukuje dalej czyli od niedzieli do wtorku.

Przykład sortowania: dziś jest środa czyli $dzien_aktualny = 3. Rekordy powinny być sortowane według dni w takiej kolejności 3,4,5,6,7,1,2

Proszę o pomoc. Zależy mi na tym aby było to w jednym zapytaniu.
Orzeszekk
Czy nie prosciej jest zapisywac datę jako format SQL DATE, lub ewentualnie unixowy timestamp (w bazie bedzie to zwykly INT, w php bedzie aktualny timestamp pobierany funkcją time())

Jesli wybierzesz uniksowy timestamp to zapytanie o x dni tygodnia w przód począwszy od dzis moze np wygladac tak:

  1. $dateInformation = getDate();
  2. $hour = 0;
  3. $minute=0;
  4. $second=0;
  5. $day = $dateInformation["day"];
  6. $month=$dateInformation["month"];
  7. $year = $dateInformation["year"];
  8. // currentTimestamp to timestamp momentu rozpoczęcia dzisiejszego dnia
  9. $currentTimestamp = mktime($hour,$minute,$second,$month,$day,$year);
  10. // maxTimestamp to górna granica wydarzeń - początek x dnia w przód
  11. $maxTimestamp = $currentTimestamp + ($ileDniWPrzód * 60*60*24);
  12. mysql_query("select * from wydarzenia where date> $currentTimestamp AND date < $maxTimestamp");


podczas zapisywania wydarzen w podobny sposob obliczasz timestamp wydarzenia, podstawiasz odpowiednie wartosci do hour,minute, second, month... i zapisujesz to w kolumnie date.
denis94
Przepraszam, nie wspomniałem, że nie mogę wykonać tego w taki sposób.
Niektóre wydarzenia potarzane są co tydzień i istnieć będzie wtedy dla niego tylko jeden rekord dlatego jedyne informacje które przechowuję to dzień i godzina.
morman
Bardzo pasuje do twojego problemu funkcja DAYOFWEEK( ),

http://www.freeopenbook.com/mysqlcookbook/...-6-sect-10.html
maly_swd
SELECT w.*, if(w.dzien>=$dzien_aktualny, 1, 0 ) as jest FROM wydarzenia ORDER BY jest desc, w.dzien ASC LIMIT 1

Albo to co masz + UNION ALL

SELECT * FROM (
SELECT * FROM wydarzenia WHERE dzien>=$dzien_aktualny ORDER BY dzien ASC LIMIT 1
UNION ALL
SELECT * FROM wydarzenia WHERE dzien<$dzien_aktualny ORDER BY dzien ASC LIMIT 1
) a
LIMIT 1
melkorm
  1. SELECT *
  2. FROM `wydarzenia`
  3. ORDER BY IF( dzien<$dzien_aktualny,dzien+7 , dzien)


Edit: mały błąd w kalkulacjach biggrin.gif
denis94
Dzięki, działa tak jak powinno, użyłem sposobu melkorma.
Mam jeszcze problem z uwzględnieniem godziny.
Mianowicie, jeżeli dziś jest poniedziałek godzina 20 to najbliższe wydarzenie pokazuje na poniedziałek o godzinie 17-tej pomimo tego, że na wtorek też jest wpisane wydarzenie.
Czyli skrypt nie uwzględnia tego, czy wydarzenie zaplanowane na dziś już minęło czy nie. Godzinę zapisuję w normalnej postaci, numerycznie.

Przykład, jeżeli aktualnie jest poniedziałek, godzina 20 - to najbliższe wydarzenie powinno być wyszukane w taki sposób: od poniedziałku o godzinie dwudziestej, do następnego poniedziałku godziny dziewiętnastej.
maly_swd
Rozwiazaniem Twojego problemu bedzie zrobienie pola DATE_TIME gdzie masz trzymana date i godzine wydazenia. Pozniej przy pomocy zwyklego WHERE albo BETWEEN mozesz wybierac co chcesz i sortowac jak chcesz:)
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.