Pregunta

Aunque puedo agrupar y ordenar en una subconsulta con alias, no puedo usar el alias en una cláusula where. ¿Necesito usar una combinación en su lugar?

Obras:

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

Falla (" columna desconocida 'avg_rating' en la cláusula 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
¿Fue útil?

Solución

Es posible que pueda hacer esto con una cláusula HAVING en lugar de WHERE

Sintaxis

Otros consejos

Haría una unión y groupby Por ejemplo,

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)

Solo el código psuedo, también recomendaría que limite las columnas de entradas a exactamente lo que necesita.

Es posible que pueda salirse con el alias como:

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
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top