> 데이터 베이스 > MySQL 튜토리얼 > 중복 행을 검색할 때 'WHERE IN(하위 쿼리)'을 사용하면 MySQL에서 성능 문제가 발생하는 이유는 무엇입니까?

중복 행을 검색할 때 'WHERE IN(하위 쿼리)'을 사용하면 MySQL에서 성능 문제가 발생하는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-22 10:20:10
원래의
527명이 탐색했습니다.

Why does using `WHERE IN (Subquery)` lead to performance issues in MySQL when searching for duplicate rows?

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

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