>데이터 베이스 >MySQL 튜토리얼 >SQL HAVING 절에서 집계 별칭을 사용할 수 없는 이유는 무엇입니까?

SQL HAVING 절에서 집계 별칭을 사용할 수 없는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-21 00:32:16639검색

Why Can't I Use an Aggregate Alias in a SQL HAVING Clause?

HAVING 절에서 집계 별칭을 사용할 수 없는 이유는 무엇입니까?

다음 SQL 문을 고려하세요.

select col1,count(col2) as col7
from --some join operation
group by col1
having col7 >= 3 -- replace col7 by count(col2) to make the code work

이 코드는 "col7"이 잘못된 열 이름임을 나타내는 오류를 생성합니다. 왜 그럴까요?

이유는 SQL 문의 실행 순서에 있습니다. HAVING 절은 SELECT 절보다 먼저 평가됩니다. 이는 HAVING 절이 평가될 때 집계 함수 count(col2)에 대한 별칭 "col7"이 아직 정의되지 않았음을 의미합니다.

SQL은 다음 순서로 쿼리를 실행합니다.

  1. FROM 절에 지정된 모든 테이블의 데카르트 곱을 계산합니다.
  2. WHERE를 기준으로 행을 필터링합니다. 절.
  3. GROUP BY 절을 기준으로 행을 그룹화합니다.
  4. HAVING 절을 기준으로 그룹을 필터링합니다.
  5. SELECT 절 대상 목록의 표현식을 평가합니다.
  6. DITINCT가 지정된 경우 중복 행을 제거합니다.
  7. Union이 있는 경우 수행합니다. 하위 선택이 존재합니다.
  8. ORDER BY 절을 기준으로 행을 정렬합니다.
  9. TOP 절이 있는 경우 적용합니다.

따라서 주어진 코드에서 , HAVING 절은 SELECT 절에 정의되기 전에 별칭 "col7"을 사용하려고 시도합니다. 문제를 해결하려면 "col7"을 집계 함수 자체로 바꾸면 됩니다.

select col1,count(col2)
from --some join operation
group by col1
having count(col2) >= 3

이렇게 하면 HAVING 절이 col2의 집계 수를 올바르게 평가할 수 있습니다.

위 내용은 SQL HAVING 절에서 집계 별칭을 사용할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.