> 데이터 베이스 > MySQL 튜토리얼 > MySQL 오류 1093을 해결하는 방법: FROM 절에 대상 테이블을 지정할 수 없습니까?

MySQL 오류 1093을 해결하는 방법: FROM 절에 대상 테이블을 지정할 수 없습니까?

Susan Sarandon
풀어 주다: 2024-12-22 07:29:09
원래의
583명이 탐색했습니다.

How to Solve MySQL Error 1093: Can't Specify Target Table in FROM Clause?

MySQL 오류 1093: FROM 절에 대상 테이블을 지정할 수 없습니다.

FROM 절을 사용하면 MySQL 오류 1093이 발생할 수 있습니다. 이는 MySQL이 선택과 직접 관련된 테이블에 대한 수정을 금지하기 때문입니다.

한 가지 대안은 테이블을 자체적으로 조인하는 것입니다. 테이블에 대한 별칭을 생성하면 해당 테이블에서 여러 번 선택하여 오류 없이 원래 테이블을 수정할 수 있습니다.

UPDATE tbl AS a
INNER JOIN tbl AS b ON a.id = b.id
SET a.col = b.col
로그인 후 복사

또 다른 해결 방법은 FROM 절에 하위 쿼리를 더 깊이 중첩:

UPDATE tbl SET col = (
  SELECT ... FROM (SELECT.... FROM) AS x);
로그인 후 복사
이 해결 방법은 하위 쿼리에서 암시적 임시 테이블을 생성하여 오류 없이 업데이트할 수 있도록 합니다. 그러나 이 방법은 성능에 영향을 미칠 수 있습니다.

MySQL 5.7.6 이상에서는 최적화 프로그램이 하위 쿼리를 최적화하여 동일한 오류가 발생할 수 있다는 점에 유의하는 것이 중요합니다. 이 문제가 발생하면 최적화를 일시적으로 비활성화하는 것이 좋습니다.

위 내용은 MySQL 오류 1093을 해결하는 방법: FROM 절에 대상 테이블을 지정할 수 없습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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