Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Specyficzne sortowanie
Forum PHP.pl > Forum > Bazy danych > MySQL
moderninternet
Witam,

Mam w bazie 3 tabele.

Tabela categories (id, title) - kategorie produktów

Tabela products (id, name, description, category) - produkty

Tabela votes (id, product_id, car_id, rating) - głosy oddane na produkty

Po wejściu w daną kategorię użytkownik wybiera filtrowanie produktów, na zasadzie produkt przydatny dla (tutaj będzie typ samochodu) i sortowanie po ilościach oddanych głosów.

Moje zapytanie wygląda następująco:

  1. SELECT * FROM products WHERE category='".$c."' AND id IN (SELECT product_id FROM votes WHERE car_id='".$car_type."') ORDER BY questionmark.gif?



Nie wiem co dopisać na końcu żeby produkty były posortowane wg parametru rating w tabeli votes. Czy wystarczy ORDER BY rating DESC w drugim zapytaniu w klauzuli IN() ?
bww
Moim zdaniem najlepiej IN zamienić na JOIN, z tabeli votes wyciągnąć interesująca kolumnę i na końcu wg. tej kolumny zrobić order by.
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.