>데이터 베이스 >MySQL 튜토리얼 >WHERE 절에서 별칭을 직접 비교할 수 없는 이유는 무엇이며 이 문제를 어떻게 해결할 수 있습니까?

WHERE 절에서 별칭을 직접 비교할 수 없는 이유는 무엇이며 이 문제를 어떻게 해결할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-19 15:26:10831검색

Why Can't I Directly Compare Aliases in a WHERE Clause, and How Can I Work Around This?

WHERE 절 별칭 제한 사항 및 해결 방법

문제:

최근 업데이트되지 않은 레코드에 대해 table_a을 쿼리할 때 WHERE 절에 별칭을 사용하면 "ORA-00904 잘못된 식별자" 오류가 발생합니다. 이는 MONTH_NO 절이 처리될 때 WHERE 별칭이 아직 정의되지 않았기 때문에 발생합니다.

예:

<code class="language-sql">SELECT A.identifier
     , A.name
     , TO_NUMBER(DECODE( A.month_no, 1, 200803, ..., NULL)) as MONTH_NO
     , TO_NUMBER(TO_CHAR(B.last_update_date, 'YYYYMM')) as UPD_DATE
  FROM table_a A, table_b B
 WHERE A.identifier = B.identifier
   AND MONTH_NO > UPD_DATE</code>

해결책:

WHERE 절은 앞에SELECT 실행되어 직접적인 별칭 사용을 방지합니다. 해결책은 하위 쿼리를 사용하는 것입니다.

<code class="language-sql">SELECT * FROM
(
  SELECT A.identifier
    , A.name
    , TO_NUMBER(DECODE( A.month_no, 1, 200803, ..., NULL)) as MONTH_NO
    , TO_NUMBER(TO_CHAR(B.last_update_date, 'YYYYMM')) as UPD_DATE
  FROM table_a A, table_b B
  WHERE A.identifier = B.identifier
) AS inner_table
WHERE MONTH_NO > UPD_DATE</code>

이 접근 방식은 먼저 내부 쿼리 내에서 별칭을 정의합니다. 그런 다음 외부 쿼리는 이미 정의된 별칭을 참조하여 "잘못된 식별자" 오류를 해결합니다. 외부 쿼리의 SELECT *은 내부 쿼리의 결과 집합에서 모든 열을 선택합니다.

위 내용은 WHERE 절에서 별칭을 직접 비교할 수 없는 이유는 무엇이며 이 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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