MySQL의 DELETE 문 하위 쿼리 제한 사항 탐색
MySQL의 DELETE
문을 WHERE
절의 하위 쿼리와 함께 사용할 때 "SQL 구문에 오류가 있습니다..." 오류가 발생할 수 있습니다. 이 제한은 하위 쿼리 내에서 대상 테이블을 참조하는 데 대한 MySQL의 제한으로 인해 발생합니다.
예시적 쿼리 및 구문 오류
하위 쿼리 조건을 기반으로 term_hierarchy
테이블에서 항목을 삭제하도록 설계된 쿼리를 살펴보겠습니다.
MySQL이 하위 쿼리의 term_hierarchy
절 내에서 삭제되는 테이블(WHERE
)을 사용하는 것을 허용하지 않기 때문에 이 쿼리는 실패합니다.
해결 방법: 중첩 하위 쿼리
해결책은 하위 쿼리를 중첩하는 데 있습니다.
해결방안 설명
원래 하위 쿼리(SELECT DISTINCT(th1.tid)
)를 다른 하위 쿼리(SELECT id FROM (...)
) 내에 캡슐화하여 임시 파생 테이블(x
)을 생성합니다. 그러면 MySQL은 DELETE
문의 WHERE
절에서 이 임시 테이블을 안전하게 사용하여 원래 제한을 효과적으로 우회할 수 있습니다.
요약
MySQL은 DELETE
문에서 하위 쿼리 사용에 제한을 두는 반면, 이 중첩 하위 쿼리 기술은 표준 구문 규칙에 의해 차단될 복잡한 삭제 작업을 수행하기 위한 실용적인 해결 방법을 제공합니다.
위 내용은 MySQL의 DELETE 문 하위 쿼리 제한을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!