Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> wybieranie z bazy najwyzszych wersji produktu
neo1986kk
post
Post #1





Grupa: Zarejestrowani
Postów: 561
Pomógł: 3
Dołączył: 2.02.2009

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


Witam mam taką bazę

id, type, nr, version, client

i chciałbym wybrać tylko te produkty, gdzie wersja jest najwyższa.

  1.  
  2. SELECT p.id, p.client, p.number, p.version, c.name, FROM products p
  3. INNER JOIN customers c ON p.client=c.id
  4. GROUP BY p.client, p.number, p.type ORDER BY p.version DESC
  5.  


i to działa jakoś dziwnie, bo czasami trafia w najwyższą wersję, a czasami nie.
Przykładowo jest sześć wersji to on pokazuje czwartą, wcześniej jeszcze miałem dołożone max(version)

  1.  
  2. SELECT p.id, p.client, p.number, max(p.version), c.name, FROM products p
  3. INNER JOIN customers c ON p.client=c.id
  4. GROUP BY p.client, p.number, p.type ORDER BY p.version DESC
  5.  


to rzeczywiście pokazywał wersję szóstą ale ID było z wersji czwartej


O czym zapomniałem?

Już sobie przypomniałem:


  1.  
  2. SELECT p.id, p.client, p.number, max(p.version), c.name FROM (SELECT * FROM products ORDER BY version DESC) p
  3. INNER JOIN customers c ON p.client=c.id
  4. GROUP BY p.client, p.number, p.type ORDER BY p.version DESC
  5.  


Ten post edytował neo1986kk 17.03.2015, 16:54:08
Go to the top of the page
+Quote Post

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: 24.08.2025 - 15:59