MySQL - SELECT WHERE 필드 IN(하위 쿼리) 성능 저하
데이터베이스에서 하위 쿼리를 사용하여 중복 행을 감지하는 것이 효율적인 접근 방식일 수 있습니다. . 그러나 중복된 필드 값이 있는 모든 행을 검색하려고 하면 WHERE IN(하위 쿼리) 쿼리에서 심각한 성능 문제가 발생할 수 있습니다. 이러한 속도 저하의 원인을 이해하면 쿼리를 최적화하는 데 도움이 될 수 있습니다.
상관 하위 쿼리 및 그 영향
이 시나리오에서 성능이 저하되는 이유는 상관 하위 쿼리를 사용하기 때문입니다. 하위 쿼리. 상관 하위 쿼리는 상위 쿼리의 값을 참조합니다. 즉, 하위 쿼리는 상위 쿼리에서 처리 중인 각 행에 대해 한 번씩 실행됩니다. 제공된 쿼리에서:
SELECT * FROM some_table WHERE relevant_field IN ( SELECT relevant_field FROM some_table GROUP BY relevant_field HAVING COUNT(*) > 1 )
하위 쿼리는 some_table에 중복된 필드 값을 반환합니다. 외부 쿼리는 some_table의 각 행을 처리할 때 관련_필드 값을 하위 쿼리에서 반환된 값과 비교합니다. 하위 쿼리는 각 중복 필드 값에 대해 여러 행을 반환하므로 이 비교에는 하위 쿼리가 여러 번 실행되어 실행 시간이 길어집니다.
상관 하위 쿼리 해결
극복하려면 상관 하위 쿼리로 인해 발생하는 성능 문제를 해결하려면 하위 쿼리를 상관되지 않은 쿼리로 변환할 수 있습니다. 이는 하위 쿼리에서 모든 열을 선택한 다음 이를 외부 쿼리에서 테이블로 사용함으로써 달성됩니다.
SELECT * FROM ( SELECT relevant_field FROM some_table GROUP BY relevant_field HAVING COUNT(*) > 1 ) AS subquery
하위 쿼리에서 모든 열을 선택하면 상위 쿼리의 값과 독립되고 한 번 실행하면 모든 중복 필드 값을 반환할 수 있습니다.
향상된 쿼리를 위해 수정됨 성능
상관되지 않은 하위 쿼리를 사용하여 성능 문제를 피하면서 some_table의 모든 중복 행을 검색하는 수정된 쿼리는 다음과 같습니다.
SELECT * FROM some_table WHERE relevant_field IN ( SELECT * FROM ( SELECT relevant_field FROM some_table GROUP BY relevant_field HAVING COUNT(*) > 1 ) AS subquery )
이 접근 방식은 다음을 제거하여 쿼리를 효과적으로 최적화합니다. 상관 하위 쿼리와 관련된 성능 단점. 이제 쿼리를 통해 중복 행을 효율적으로 검색할 수 있으므로 잠재적인 데이터 이상 현상을 검사 및 분석할 수 있습니다.
위 내용은 중복 행을 검색할 때 'WHERE IN(하위 쿼리)'을 사용하면 MySQL에서 성능 문제가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!