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 중국어 웹사이트의 기타 관련 기사를 참조하세요!