Frage

Zwar kann ich die Gruppe und die Bestellung mit einer alias-sub-Abfrage, ich kann nicht verwenden Sie den alias in der where-Klausel.Brauche ich einen join statt?

Werke:

SELECT entries.*, 
    (SELECT avg(value) 
    FROM `ratings`
    WHERE ratings.entry_id = entries.id) as avg_rating
FROM `entries` 
ORDER BY avg_rating DESC

Fehl ("unbekannte Spalte 'avg_rating' in where-Klausel"):

SELECT entries.*, 
    (SELECT avg(value) 
    FROM `ratings` 
    WHERE ratings.entry_id = entries.id) as avg_rating 
FROM `entries` 
WHERE avg_rating < '4.5000' ORDER BY avg_rating DESC
War es hilfreich?

Lösung

Sie können in der Lage sein, dies zu tun mit einer HAVING-Klausel anstelle einer WO

Syntax

Andere Tipps

Ich würde eine beitreten und groupby Für Beispiel,

SELECT entries.*, AVG(value)
FROM entries INNER JOIN ratings ON entries.id = ratings.entry_id 
GROUP BY entries.*
HAVING AVG(value) < '4.5000' 
ORDER BY AVG(value)

Nur Pseudo-code, ich würde auch empfehlen, begrenzen Sie die Einträge der Spalten genau das, was Sie brauchen.

Sie könnten in der Lage sein, um Weg mit dem alias wie:

SELECT entries.*, AVG(value) as avg_value
FROM entries INNER JOIN ratings ON entries.id = ratings.entry_id 
GROUP BY entries.*
HAVING avg_value < '4.5000' 
ORDER BY avg_value
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top