![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 24 Pomógł: 0 Dołączył: 8.07.2006 Ostrzeżenie: (0%) ![]() ![]() |
Witam
Mam problem z napisaniem zapytania do bazy MySQL. Mecze sie z tym juz 2 dni i nie widac konca. Mam 2 tabele zawierajace wpisy uzytkownikow: Articles (Id, AuthorId, Votes, Rate) Texts (Id, AuthorId, Votes, Rate) Pole AuthorId to odeslanie do Id z tabeli uzytkownikow. Pola Votes, Rate mam do wyliczania sredniej ocen oddanych na te publikacje obliczam przez zaokraglenie Rate/Votes (przy glosowaniu zwiekszam Votes o 1 i dodaje ocene do Rate). Moj problem polega na tym, ze w jednym zapytaniu chce: - chce pobrac dane z tabeli uzytkownika (Id, Login, etc.) - posortowac uzytkownikow ze wzgledu na srednia dodanych przez nich publikacji (srednia razem z obu tabel) - zbior wynikow ograniczyc tylko do tych uzytkownikow, ktorzy maja co najmniej 5 publikacji (obojetnie z ktorej tabeli) Czyli staram sie wykombinowac cos w stylu:
No i nie dziala i wiele innych kombinacji podobnego kodu tez nie dziala. ORDER BY nie widzi tak jakby tych pobranych pol. Czy ktos moze mi pomoc, ewentualnie podeslac linka do jakiejs publikacji gdzie znajde informacje na temat popelnianego bledu? Z gory dzieki! Pozdrawiam |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Moderatorzy Postów: 6 072 Pomógł: 861 Dołączył: 10.12.2003 Skąd: Dąbrowa Górnicza ![]() |
Problem leży pewnie w tym, że w klauzuli ORDER BY stosujesz aliasy kolumn, a z tego co się orientuję takie coś nie przejdzie. Nie wiem czy we wszystkich wersjach MySQL tak nadal jest ale wcześniej taki problem występował. Poza tym - w Twoim przypadku zdecydowanie lepiej złamać postać normalną i mimo wszystko wejść w redundację danych. Ja bym utworzył osobne kolumny w tabeli, które będą przechowywać wartości, które aktualnie obliczasz podzapytaniami. Dodatkowo należałoby odpalić triggera na wszystkich operacjach (INSERT, UPDATE, DELETE) aktualizującego pola dla danego rekordu. Wydajność powinna zwiększyć się znacząco i unikniesz problemów z ORDER BY.
|
|
|
![]() ![]() |
![]() |
Aktualny czas: 5.10.2025 - 11:07 |