JOIN은 기본적으로 WHERE보다 빠릅니까?
연결된 테이블에서 데이터를 검색하는 두 개의 유사한 쿼리를 비교할 때 하나는 WHERE 절을 사용합니다. 다른 하나는 JOIN을 사용하는 경우 다음과 같은 질문이 발생합니다. 상당한 성능이 있습니까? 차이가 있습니까?
데이터베이스 스키마:
다음 데이터베이스 스키마를 고려하십시오.
CREATE TABLE Document ( Id INT PRIMARY KEY, Name VARCHAR 255 ); CREATE TABLE DocumentStats ( Id INT PRIMARY KEY, DocumentId INT, -- foreign key to table Document NbViews INT );
쿼리 비교:
조회수가 500회가 넘는 문서를 검색하려면 다음 중 하나를 사용할 수 있습니다. WHERE 절 또는 JOIN 연산:
-- WHERE clause SELECT * FROM Document, DocumentStats WHERE DocumentStats.Id = Document.Id AND DocumentStats.NbViews > 500; -- JOIN operation SELECT * FROM Document INNER JOIN DocumentStats ON Document.Id = DocumentStats.Id WHERE DocumentStats.NbViews > 500;
이론적 동등성:
이론적으로 두 쿼리는 동일한 결과를 생성해야 합니다. 데이터베이스 쿼리 최적화 프로그램은 사용된 쿼리 구문에 관계없이 실행 시간을 최소화하는 최적의 실행 계획을 생성하도록 설계되었습니다.
그러나 특정한 경우 일부 데이터베이스 엔진은 특정 쿼리에 대해 다른 쿼리보다 더 효율적인 계획을 생성할 수 있습니다. 복잡한 쿼리 또는 데이터베이스 구성의 경우 두 접근 방식을 모두 테스트하면 잠재적인 성능 이점을 확인할 수 있습니다.
따라서 유사한 쿼리에 대한 JOIN 및 WHERE 절은 일반적으로 동일한 것으로 간주되지만 항상 대상 데이터베이스 시스템에서 테스트하여 다음을 수행하는 것이 좋습니다. 데이터베이스별 최적화 또는 예상치 못한 동작을 식별합니다.
위 내용은 관련 테이블 쿼리에 대한 JOIN은 항상 WHERE 절보다 빠르나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!