MySQL 오류 1093: 제한 사항 이해 및 극복
MySQL에서 FROM 절에서도 참조되는 테이블을 수정하려고 합니다. 동일한 쿼리로 인해 "FROM 절에서 업데이트할 대상 테이블 'table_name'을 지정할 수 없습니다."라는 오류가 발생할 수 있습니다. 이러한 제한은 MySQL이 이러한 작업을 직접 수행할 수 없기 때문에 발생합니다.
이 문제를 해결하려면 다음과 같은 여러 접근 방식을 고려할 수 있습니다.
테이블 자체에 조인
한 가지 옵션은 적절한 선택 기준을 사용하여 테이블을 자체적으로 조인하여 MySQL의 관점에서 테이블의 두 개의 개별 인스턴스를 생성하는 것입니다. 이를 통해 다른 인스턴스는 그대로 두고 한 인스턴스에서 파괴적인 작업을 수행할 수 있습니다.
FROM 절에 하위 쿼리 중첩
대체 해결 방법은 대상을 생성하는 하위 쿼리를 중첩하는 것입니다. 더 깊은 FROM 절 내에서 삭제할 행입니다. 이는 MySQL이 대상 테이블과 별도의 엔터티로 인식하는 하위 쿼리에서 암시적 임시 테이블을 생성합니다. 그러나 이 접근 방식은 성능에 영향을 미칠 수 있습니다.
최적화 프로그램 최적화 비활성화(MySQL 5.7.6 이상)
MySQL 5.7.6부터 최적화 프로그램은 다음을 최적화할 수 있습니다. FROM 절의 하위 쿼리로 인해 오류가 지속됩니다. 이 문제를 해결하려면 Optimizer_switch 변수를 사용하여 최적화를 비활성화하세요.
SET optimizer_switch = 'derived_merge=off';
이 방법은 전체 쿼리 성능에 부정적인 영향을 미칠 수 있으므로 단기적인 솔루션이나 작은 일회성 작업에 권장됩니다.
결론
업데이트할 대상 테이블 'table_name'을 지정할 수 없습니다. FROM 절에서"라는 오류는 FROM 절에서도 사용되는 테이블을 수정하는 데 있어 MySQL의 제한 사항에서 비롯됩니다. 위에 설명된 방법을 사용하면 개발자는 이러한 제한을 극복하고 데이터에 대해 원하는 작업을 수행할 수 있습니다.
위 내용은 MySQL 오류 1093: 'FROM 절에서 업데이트할 대상 테이블 'table_name'을 지정할 수 없습니다'를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!