> 데이터 베이스 > MySQL 튜토리얼 > MySQL 오류 1093: 'FROM 절에서 업데이트할 대상 테이블 'table_name'을 지정할 수 없습니다'를 해결하는 방법은 무엇입니까?

MySQL 오류 1093: 'FROM 절에서 업데이트할 대상 테이블 'table_name'을 지정할 수 없습니다'를 해결하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-24 15:12:15
원래의
608명이 탐색했습니다.

How to Solve MySQL Error 1093:

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

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