>데이터 베이스 >MySQL 튜토리얼 >MySQL 업데이트 쿼리에서 '테이블이 두 번 지정되었습니다' 오류가 발생하는 이유는 무엇입니까?

MySQL 업데이트 쿼리에서 '테이블이 두 번 지정되었습니다' 오류가 발생하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-23 08:03:32628검색

Why Do I Get

오류: "테이블이 'UPDATE'의 대상과 별도의 데이터 소스로 두 번 지정되었습니다."

업데이트가 포함된 MySQL 쿼리를 실행할 때 테이블을 동일한 쿼리 내에서 데이터 원본으로 참조하면 "테이블이 두 번 지정되었습니다."라는 오류가 발생할 수 있습니다. 이 오류는 동일한 테이블이 UPDATE 문의 대상이고 업데이트 기준을 결정하는 데 사용되는 하위 쿼리에서 별도의 테이블로 나타날 때 발생합니다.

이 오류를 해결하고 원하는 테이블을 성공적으로 업데이트하려면 다음을 따르세요. 단계:

  1. 하위 쿼리 추출: 문제를 일으키는 UPDATE 문 내에서 하위 쿼리를 식별합니다. 제공된 예에서 하위 쿼리는 다음과 같습니다.
SELECT m2.branch_id FROM manager AS m2 WHERE (m2.branch_id, m2.year) IN (...)
  1. 파생 테이블 생성: 하위 쿼리를 다른 SELECT 문으로 래핑하고 그것에 대한 별칭. 이렇게 하면 관리자 테이블을 명시적으로 두 번 지정하지 않고도 하위 쿼리를 참조할 수 있습니다.
SELECT * FROM (SELECT m2.branch_id FROM manager AS m2 WHERE (m2.branch_id, m2.year) IN (...)) AS subquery
  1. 파생 테이블 사용: 원래 하위 쿼리를 파생 테이블로 바꿉니다. UPDATE 문에서.
UPDATE manager
SET status = 'Y'
WHERE branch_id IN (
    SELECT branch_id
    FROM subquery
);

파생 테이블을 사용하면 관리자 테이블을 대상 및 데이터 소스로 사용하여 "테이블이 두 번 지정되었습니다" 오류를 해결했습니다. 이 기술을 사용하면 하위 쿼리가 한 번만 참조되고 UPDATE 문이 성공적으로 실행될 수 있습니다.

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

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