조인 문 최적화:
Mysql4.1은 SQL 하위 쿼리를 지원하기 시작합니다. 이 기술을 사용하면 SELECT 문을 사용하여 쿼리 결과의 단일 열을 만든 다음 이 결과를 다른 쿼리의 필터 조건으로 사용할 수 있습니다. 하위 쿼리를 사용하면 논리적으로 한 번에 여러 단계를 완료해야 하는 많은 SQL 작업을 완료할 수 있으며 트랜잭션 또는 테이블 잠금을 피할 수도 있고 작성하기도 쉽습니다. 그러나 경우에 따라 하위 쿼리를 보다 효율적인 조인(JOIN)으로 대체할 수 있습니다..
.
주문 기록이 없는 모든 사용자를 추출한다고 가정하면 다음 쿼리를 사용하여 이를 완료할 수 있습니다.
SELECT * FROM customerinfo WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo)
연결을 사용하는 경우 (JOIN). 이 쿼리를 완료하면 속도가 훨씬 빨라집니다. 특히 salesinfo 테이블에 CustomerID에 대한 인덱스가 있는 경우 쿼리는 다음과 같습니다.
SELECT * FROM customerinfo LEFT JOIN salesinfoON customerinfo.CustomerID=salesinfo.CustomerID
WHERE salesinfo.CustomerID IS NULL
Join(JOIN).. 이것이 더 효율적인 이유는 MySQL이 이 논리적 2단계 쿼리를 완료하기 위해 메모리에 임시 테이블을 생성할 필요가 없기 때문입니다.
위 내용은 mysql 최적화된 조인문 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!