4

エイリアス化されたサブクエリでグループ化して並べ替えることはできますが、where 句でエイリアスを使用することはできません。代わりに結合を使用する必要がありますか?

作品:

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

失敗 ("where 句の不明な列 'avg_rating'"):

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
4

2 に答える 2

3

WHERE の代わりに HAVING 句を使用してこれを行うことができる場合があります

構文

于 2009-07-30T21:06:48.003 に答える
3

たとえば、join と groupby を実行します。

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)

単なる疑似コードですが、エントリ列を必要なものだけに制限することもお勧めします。

次のようなエイリアスを使用して回避できる場合があります。

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
于 2009-07-30T21:10:44.627 に答える