2009-07-30 27 views
0

Bien que je puisse regrouper et ordonner par sur une sous-requête aliasée, je ne peux pas utiliser l'alias dans une clause where. Ai-je besoin d'utiliser une jointure à la place?MySQL where clause et commande par avg() comme sous-requête

Travaux:

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

ne réussit pas ("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 

Répondre

2

Vous pourriez être en mesure de le faire avec une clause HAVING au lieu d'un OU

Syntax

3

je ferais une jointure et 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 code de psuedo, je vous recommande également de limiter les colonnes d'entrées à exactement ce dont vous avez besoin.

Vous pourriez être en mesure de sortir avec l'alias tels 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