Pergunta

Embora eu possa agrupar e encomendar em uma subsesão alias, não posso usar o alias em uma cláusula onde. Eu preciso usar uma junção?

Funciona:

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

Falha ("coluna desconhecida 'avg_rating' em onde cláusula"):

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
Foi útil?

Solução

Você pode fazer isso com uma cláusula tendo em vez de um onde

Sintaxe

Outras dicas

Eu faria uma junção e um grupo por exemplo,

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)

Apenas o código PSUDO, eu também recomendaria que você limite as colunas de entradas exatamente ao que você precisa.

Você pode se safar com o pseudônimo 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 em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top