> 데이터 베이스 > MySQL 튜토리얼 > MySQL의 WHERE 절에 별칭을 사용할 수 있나요?

MySQL의 WHERE 절에 별칭을 사용할 수 있나요?

Barbara Streisand
풀어 주다: 2025-01-20 02:09:09
원래의
508명이 탐색했습니다.

Can I Use Aliases in MySQL's WHERE Clause?

MySQL WHERE 절: 별칭 제한

MySQL은 가독성을 높이고 쿼리 내에서 새로운 표현식을 생성하기 위해 열 별칭을 허용합니다. 그러나 WHERE 절 내에서 별칭을 직접 사용하면 "알 수 없는 열" 오류가 발생하는 경우가 많습니다. 이는 WHERE 절이 별칭이 할당되기 전에 행을 필터링하기 때문입니다.

해결 방법:

한 가지 해결 방법은 HAVING 절을 사용하는 것입니다. WHERE과 달리 HAVING은 그룹화 및 집계 이후 작업을 수행하여 쿼리 내에서 생성된 별칭을 참조할 수 있습니다.

<code class="language-sql">SELECT *, AVG(rev_rating) AS avg_rating
FROM reviews
GROUP BY rev_id
HAVING avg_rating > 5;</code>
로그인 후 복사

여기 avg_ratingHAVING에서 올바르게 참조되었습니다.

WHERE 절에서 유사한 필터링을 수행하려면 별칭을 완전한 식으로 바꿔야 합니다.

<code class="language-sql">SELECT *
FROM reviews
WHERE (SUM(reviews.rev_rating) / COUNT(reviews.rev_id)) > 5;</code>
로그인 후 복사

중요 고려 사항:

WHERE 절은 모든 표현식, 특히 별칭 내에서 사용되는 SUM() 또는 AVG()과 같은 집계 함수를 지원하지 않습니다. 그럴땐 HAVING가 필수입니다.

MySQL 문서에 설명된 대로 WHERE에서 열 별칭을 참조하는 것은 WHERE 절 실행 시 해당 값이 계산되지 않을 수 있으므로 허용되지 않습니다.

위 내용은 MySQL의 WHERE 절에 별칭을 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿