집 >데이터 베이스 >MySQL 튜토리얼 >WHERE 절에서 별칭을 직접 비교할 수 없는 이유는 무엇이며 이 문제를 어떻게 해결할 수 있습니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!