Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [MySQL] Podzapytania z użyciem MAX, dlaczego operator "=" nie działa?
qweluke
post
Post #1





Grupa: Zarejestrowani
Postów: 87
Pomógł: 0
Dołączył: 25.03.2010
Skąd: Radom

Ostrzeżenie: (10%)
X----


Witam,

Takim zapytaniem
  1. SELECT uzytkownicy.id, MAX( graf.id_graf ) AS maksik, id_uzytkownika, id_graf, miesiac
  2. FROM `graf` , `uzytkownicy`
  3. WHERE uzytkownicy.id = graf.id_uzytkownika
  4. AND id_graf = 'maksik'
  5. GROUP BY uzytkownicy.id
  6. ORDER BY nazwisko ASC


Dostaje coś takigo
(IMG:http://i.imgur.com/2mL6M.jpg)

Co oczywiście jest nieprawdą, gdyż przy użyciu takiego zapytania

  1. SELECT uzytkownicy.id, MAX( graf.id_graf ) AS maksik, id_uzytkownika, id_graf, miesiac
  2. FROM `graf` , `uzytkownicy`
  3. WHERE uzytkownicy.id = grafik.id_uzytkownika
  4. GROUP BY uzytkownicy.id
  5. ORDER BY nazwisko ASC


zwraca mi:
(IMG:http://i.imgur.com/ENHzq.jpg)


A tak wygląda tabela "graf":
(IMG:http://i.imgur.com/Ok9We.jpg)

---------------------------------------
1. Ktoś mi może wytłumaczyć dlaczego porównanie z pierwszej opcji nie wyciąga prawidłowych danych?
2. Jak zatem powinno brzmieć zapytanie, aby dla każdego użytkownika pobrać wpis gdzie id_graf jest największe?

Ten post edytował qweluke 20.09.2011, 12:44:14
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
qweluke
post
Post #2





Grupa: Zarejestrowani
Postów: 87
Pomógł: 0
Dołączył: 25.03.2010
Skąd: Radom

Ostrzeżenie: (10%)
X----


o! tego mi było trzeba (IMG:style_emoticons/default/biggrin.gif)

  1. SELECT uzytkownicy.id, id_uzytkownika, id_graf, miesiac,
  2. FROM `graf` , `uzytkownicy`
  3. WHERE uzytkownicy.id = graf.id_uzytkownika
  4. AND id_graf IN (SELECT MAX( graf.id_graf) FROM graf, uzytkownicy WHERE uzytkownicy.id=graf.id_uzytkownika AND id_uzytkownika=uzytkownicy.id GROUP BY id)
  5. GROUP BY uzytkownicy.id
  6. ORDER BY nazwisko ASC


teraz śmiga jak ta lala (IMG:style_emoticons/default/biggrin.gif)

to jeszcze jedno pytanie

  1. SELECT uzytkownicy.id, id_uzytkownika, id_graf, miesiac,
  2. FROM `graf` , `uzytkownicy`
  3. WHERE uzytkownicy.id = graf.id_uzytkownika
  4. AND id_graf IN (SELECT MAX( graf.id_graf) FROM graf, uzytkownicy WHERE uzytkownicy.id=graf.id_uzytkownika AND id_uzytkownika=uzytkownicy.id GROUP BY id)
  5. GROUP BY uzytkownicy.id
  6. ORDER BY nazwisko ASC


To zapytanie zwraca tylko uzytkownikow ktorzy maja najwieksze id_graf.
Musiałem je troche zedytowac i wyglada teraz tak

  1. SELECT uzytkownicy.id, id_uzytkownika, id_graf, miesiac,
  2. FROM `graf` , `uzytkownicy`
  3. WHERE uzytkownicy.id = graf.id_uzytkownika
  4. AND id_graf IN (SELECT MAX( graf.id_graf) FROM graf, uzytkownicy WHERE uzytkownicy.id=graf.id_uzytkownika AND id_uzytkownika=uzytkownicy.id AND miesiac=201109 GROUP BY id)
  5. GROUP BY uzytkownicy.id
  6. ORDER BY nazwisko ASC


I w takim przypadku zwroci mi tylko uzytkownikow, ktorzy maja wpisana jakas wartosc id_graf.
Jak zmodyfikowac zapytanie aby wyswietlic wszystkich uzytkownikow ktorzy maja max(id_graf) oraz tych ktorzy nie maja wpisanej zadnej wartosci?

Probowalem INNER JOIN'em ale nie wyswietla mi tych "pustych" uzytkownikow :/

  1. SELECT uzytkownicy.id, id_uzytkownika, id_graf, miesiac,
  2. FROM `graf` , `uzytkownicy`
  3. WHERE uzytkownicy.id = graf.id_uzytkownika
  4. OR id_graf IN (SELECT MAX( graf.id_graf) FROM graf, uzytkownicy WHERE uzytkownicy.id=graf.id_uzytkownika AND id_uzytkownika=uzytkownicy.id AND miesiac=201109)
  5. GROUP BY uzytkownicy.id
  6. ORDER BY nazwisko ASC


Wstawilem OR zamiast AND, teraz wysweitla mi wszystkich uzytkownikow z IDmax oraz pozostalych z pierwszym lepszym ID.
Także jeżeli nie wpadne na inny pomysl to zabezpiecze to przez PHP zeby sprawdzal czy aktualne ID jest MAX i w przeciwnym wypadku wyswietlal stosowne informacje.

Chyba ze mi podpowiecie jak uzyskac informacje z MySQL z wszystkimi danymi a dla uzytkownikow ktorzy nie maja w danym miesiacu MAX(id) wyswietlalo NULL lub pusta komorke?
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: 27.12.2025 - 05:02