Question

Bien que je puisse grouper et ordonner par sur une sous-requête avec alias, je ne peux pas utiliser l'alias dans une clause where. Dois-je utiliser une jointure à la place?

Fonctionne:

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

Échec ("colonne inconnue 'avg_rating' dans la clause where"):

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
Était-ce utile?

La solution

Vous pourrez peut-être faire cela avec une clause HAVING au lieu d'un WHERE

Syntaxe

Autres conseils

Je ferais une jointure et un groupby Par exemple,

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)

Juste du code psuedo, je vous recommanderais également de limiter les colonnes d'entrées à ce dont vous avez besoin.

Vous pourrez peut-être vous en tirer avec un alias tel que:

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
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top