Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Mysql SELECT - Sortowanie uwzględniające dzień tygodnia.
denis94
post
Post #1





Grupa: Zarejestrowani
Postów: 68
Pomógł: 0
Dołączył: 8.08.2010
Skąd: Warszawa

Ostrzeżenie: (0%)
-----


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.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
Orzeszekk
post
Post #2





Grupa: Zarejestrowani
Postów: 260
Pomógł: 14
Dołączył: 8.09.2011

Ostrzeżenie: (0%)
-----


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.

Ten post edytował Orzeszekk 27.02.2012, 00:00:05
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 8.10.2025 - 04:58