하위 쿼리를 사용할 때 MySQL에서 '테이블이 두 번 지정되었습니다' 오류를 해결하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-11-12 15:02:02
원래의
439명이 탐색했습니다.

How to Resolve the

MySQL 오류: 테이블이 두 번 지정됨

테이블을 데이터 소스로 사용하면서 테이블을 업데이트하려고 하면 MySQL에서 오류가 발생할 수 있습니다. 테이블이 두 번 지정되었음을 나타냅니다. 이는 일반적으로 테이블 별칭과 함께 하위 쿼리를 사용할 때 발생합니다.

예를 들어 다음 쿼리를 고려해보세요.

UPDATE manager AS m1
SET m1.status = 'Y'
WHERE m1.branch_id IN (
  SELECT m2.branch_id
  FROM manager AS m2
  WHERE (m2.branch_id, m2.year) IN (
    SELECT DISTINCT branch_id, year
    FROM branch_master
    WHERE type = 'finance'
  )
);
로그인 후 복사

이 쿼리는 특정 필드가 있는지 확인하는 하위 쿼리를 기반으로 관리자 테이블을 업데이트하려고 시도합니다. 관리자에서 유형이 'finance'인 Branch_master 테이블의 값과 일치합니다. 그러나 MySQL은 관리자 테이블이 대상(UPDATE 절에서)과 데이터 소스(하위 쿼리에서)로 모두 사용된다는 사실에 반대합니다.

이 문제를 해결하고 "테이블이 두 번 지정됨" 오류가 발생하면 하위 쿼리에 파생 테이블을 사용할 수 있습니다. 여기에는 원본 테이블을 기반으로 임시 테이블을 생성한 다음 해당 파생 테이블에서 선택하는 작업이 포함됩니다.

FROM (SELECT * FROM manager) AS m2
로그인 후 복사

원래 관리자 테이블을 괄호로 묶고 결과에 별칭을 m2로 지정하여 새 파생 테이블을 생성합니다. 이를 통해 관리자 이름을 명시적으로 두 번 지정하지 않고도 관리자 테이블에서 데이터를 선택할 수 있습니다.

업데이트된 쿼리:

UPDATE manager
SET status = 'Y'
WHERE branch_id IN (
  SELECT branch_id
  FROM (SELECT * FROM manager) AS m2
  WHERE (m2.branch_id, m2.year) IN (
    SELECT branch_id, year
    FROM branch_master
    WHERE type = 'finance'
  )
);
로그인 후 복사

이 업데이트된 쿼리는 하위 쿼리에 대해 파생 테이블을 올바르게 사용하여 "테이블이 두 번 지정되었습니다" 오류가 발생하고 쿼리가 성공적으로 실행됩니다.

위 내용은 하위 쿼리를 사용할 때 MySQL에서 '테이블이 두 번 지정되었습니다' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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