문제

별칭 하위 쿼리로 그룹 및 주문을 할 수 있지만 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 Clause에서 "알 수없는 열 '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
도움이 되었습니까?

해결책

당신은 어디에있는 대신 조항으로 이것을 할 수 있습니다.

통사론

다른 팁

예를 들어 가입과 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)

PSUEDO 코드 만 있으면 항목 열을 정확히 필요한 것으로 제한하는 것이 좋습니다.

다음과 같은 별칭으로 도망 갈 수 있습니다.

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