> 데이터 베이스 > MySQL 튜토리얼 > MySQL의 DELETE 문 하위 쿼리 제한을 해결하는 방법은 무엇입니까?

MySQL의 DELETE 문 하위 쿼리 제한을 해결하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2025-01-10 18:17:10
원래의
409명이 탐색했습니다.

How to Work Around MySQL's DELETE Statement Subquery Restrictions?

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

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