> 데이터 베이스 > MySQL 튜토리얼 > MySQL 하위 쿼리의 EXISTS와 IN: 어느 것이 더 나은 성능을 발휘합니까?

MySQL 하위 쿼리의 EXISTS와 IN: 어느 것이 더 나은 성능을 발휘합니까?

Patricia Arquette
풀어 주다: 2025-01-03 08:44:39
원래의
889명이 탐색했습니다.

EXISTS vs. IN in MySQL Subqueries: Which Performs Better?

MySQL에서 EXISTS와 IN을 사용하는 하위 쿼리: 성능 비교

하위 쿼리는 데이터베이스에서 특정 데이터를 추출하는 데 중요한 역할을 합니다. 두 가지 일반적인 하위 쿼리 방법은 EXISTS와 IN입니다. 둘 다 비슷한 결과를 얻을 수 있지만 서로 다른 성능 특성을 나타냅니다.

다음 두 쿼리를 고려하세요.

방법 1:

SELECT *
FROM tracker
WHERE reservation_id IN (
    SELECT reservation_id
    FROM tracker
    GROUP BY reservation_id
    HAVING
        (
            method = 1
            AND type = 0
            AND Count(*) > 1
        )
        OR (
            method = 1
            AND type = 1
            AND Count(*) > 1
        )
        OR (
            method = 2
            AND type = 2
            AND Count(*) > 0
        )
        OR (
            method = 3
            AND type = 0
            AND Count(*) > 0
        )
        OR (
            method = 3
            AND type = 1
            AND Count(*) > 1
        )
        OR (
            method = 3
            AND type = 3
            AND Count(*) > 0
        )
);
로그인 후 복사

방법 2:

SELECT *
FROM tracker t
WHERE EXISTS (
    SELECT reservation_id
    FROM tracker t3
    WHERE
        t3.reservation_id = t.reservation_id
    GROUP BY reservation_id
    HAVING
        (
            METHOD = 1
            AND TYPE = 0
            AND COUNT(*) > 1
        )
        OR (
            METHOD = 1
            AND TYPE = 1
            AND COUNT(*) > 1
        )
        OR (
            METHOD = 2
            AND TYPE = 2
            AND COUNT(*) > 0
        )
        OR (
            METHOD = 3
            AND TYPE = 0
            AND COUNT(*) > 0
        )
        OR (
            METHOD = 3
            AND TYPE = 1
            AND COUNT(*) > 1
        )
        OR (
            METHOD = 3
            AND TYPE = 3
            AND COUNT(*) > 0
        )
);
로그인 후 복사

성능 측면에서 방법 2는 방법 1보다 훨씬 뛰어나며 실행 시간이 10초 이상인 데 비해 1초도 채 걸리지 않습니다. 이러한 불일치의 이유를 이해하려면 각 방법의 내부 작동 방식을 자세히 조사해야 합니다.

EXISTS 대 IN: 주요 차이점

  • EXISTS : 하위 쿼리와 일치하는 행이 하나 이상 있는지 확인합니다. 그렇다면 true를 반환합니다. 그렇지 않으면 false를 반환합니다. 행 자체를 검색하는 대신 행 존재에 의존합니다.
  • IN: 외부 쿼리의 값을 하위 쿼리의 각 행과 비교합니다. 일치하는 항목이 발견되면 true를 반환합니다. 그렇지 않으면 false를 반환합니다. 하위 쿼리의 모든 행에 대해 실행됩니다.

성능 고려 사항

  • 하위 쿼리 크기: 하위 쿼리가 큰 값을 반환하는 경우 IN은 모든 행과 비교할 때 비용이 많이 들 수 있습니다. 반대로 EXISTS는 일치하는 행 하나만 찾으면 되므로 대규모 하위 쿼리에 더 효율적입니다.
  • Null 값: EXISTS는 IN보다 Null 값을 더 효율적으로 처리할 수 있습니다. IN이 포함된 하위 쿼리가 null을 반환하면 null을 외부 쿼리로 전파할 수 있습니다. 그러나 EXISTS는 null을 false로 처리합니다.
  • 최적화: MySQL은 인덱스를 사용하여 EXISTS를 최적화할 수 있는 반면, IN은 구체화 또는 구체화된 뷰 사용과 같은 추가 최적화가 필요할 수 있습니다.

결론

일반적으로, EXISTS는 하위 쿼리가 많은 수의 행을 반환할 것으로 예상되거나 null 값이 포함된 경우 권장됩니다. 작은 하위 쿼리의 경우 IN이 더 성능이 좋을 수 있습니다. 특정 쿼리에 대한 최선의 접근 방식을 결정하려면 항상 계획 설명을 사용하는 것이 좋습니다.

위 내용은 MySQL 하위 쿼리의 EXISTS와 IN: 어느 것이 더 나은 성능을 발휘합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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