Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [SQL]Sortowanie wyników wg. daty
maksik
post 9.08.2016, 11:03:52
Post #1





Grupa: Zarejestrowani
Postów: 206
Pomógł: 0
Dołączył: 26.09.2012

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


Poniższym zapytaniem otrzymuję następujący wynik
  1. SELECT date, COUNT(results.id) wynik FROM results GROUP BY DATE_FORMAT(date, '%Y%m%d') ORDER BY date DESC LIMIT 0,4


2016-08-07 - 4
2016-08-05 - 42
2016-08-04 - 14
2016-08-03 - 44

Jak widać w wyniku nie podało daty 2016-08-06 ponieważ "wynik" wynosił 0, jak to uwzględnić, aby zapytanie również wyświetlało wszystkie daty nawet te z wynikiem 0?
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 6)
nospor
post 9.08.2016, 11:07:44
Post #2





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




Cytat
Jak widać w wyniku nie podało daty 2016-08-06 ponieważ "wynik" wynosił 0,
Nie, nie podalo tej daty, poniewaza ta data w bazie nie istnieje. Zapytania operuja na istniejacych rekordach a nie urojonych


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
maksik
post 9.08.2016, 11:10:15
Post #3





Grupa: Zarejestrowani
Postów: 206
Pomógł: 0
Dołączył: 26.09.2012

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


czyli trzeba już w PHP tworzyć dalej funkcje która będzie wykrywała braki? w samym mysql już nic się nie poradzi?
Go to the top of the page
+Quote Post
nospor
post 9.08.2016, 11:10:38
Post #4





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




Tak, lataj dziury w php


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
aras785
post 9.08.2016, 11:14:26
Post #5





Grupa: Zarejestrowani
Postów: 859
Pomógł: 177
Dołączył: 29.10.2009

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


Ja dla wykresów robiłem mniej więcej tak:

  1. <?php
  2. //zapytanie:SELECT date, COUNT(results.id) wynik FROM results GROUP BY DATE_FORMAT(date, '%Y%m%d') ORDER BY date DESC LIMIT 0,4
  3. foreach ($sql as $wynik) {
  4. $dni_z_bazy[$wynik['date']] = $wynik['wynik'];
  5. }
  6.  
  7. for ($i = 0; $i < 30; $i++) {
  8. $dzien = (($i == 0) ? date("Y-m-d") : date("Y-m-d", strtotime("-$i day")));
  9. if (array_key_exists($dzien, $dni_z_bazy)) {
  10. echo $dzien . ': ' . $dni_z_bazy[$dzien] . '<br>';
  11. } else {
  12. echo $dzien . ': 0<br>';
  13. }
  14.  
  15. }


Ten post edytował aras785 9.08.2016, 11:14:48
Go to the top of the page
+Quote Post
trueblue
post 9.08.2016, 11:18:35
Post #6





Grupa: Zarejestrowani
Postów: 6 799
Pomógł: 1827
Dołączył: 11.03.2014

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


Możesz zrobić kalendarz na dany rok (wszystkie dni) i spiąć z tą tabelą poprzez LEFT JOIN.


--------------------
Go to the top of the page
+Quote Post
nospor
post 9.08.2016, 11:19:05
Post #7





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




@aras
strtotime("-0 day"); generuje jakies bledy?


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 17.06.2025 - 13:09