Предложение MySQLwhere и упорядочивание с помощью avg() в качестве подзапроса
Вопрос
Хотя я могу группировать и упорядочивать подзапросы с псевдонимами, я не могу использовать псевдоним в предложении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
Не связан с StackOverflow