Предложение MySQLwhere и упорядочивание с помощью avg() в качестве подзапроса

StackOverflow https://stackoverflow.com/questions/1209364

Вопрос

Хотя я могу группировать и упорядочивать подзапросы с псевдонимами, я не могу использовать псевдоним в предложенииwhere.Нужно ли мне вместо этого использовать соединение?

Работает:

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

Сбой («неизвестный столбец «avg_rating» в пункте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
Это было полезно?

Решение

Возможно, вы сможете сделать это с помощью предложения HAVING вместо WHERE.

Синтаксис

Другие советы

Я бы сделал соединение и группировку. Например,

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
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top