>데이터 베이스 >MySQL 튜토리얼 >MySQL 뷰는 효율적인 쿼리를 위해 인덱스를 활용할 수 있습니까?

MySQL 뷰는 효율적인 쿼리를 위해 인덱스를 활용할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-10 00:47:02806검색

Can MySQL Views Leverage Indexes for Efficient Queries?

MySQL 뷰가 쿼리에 인덱스를 활용할 수 있나요?

MySQL이 뷰 쿼리에 인덱스를 활용하는 것은 간단하지 않습니다. 기본 테이블에 인덱스가 있음에도 불구하고 뷰 쿼리는 별도로 처리되어 잠재적으로 비효율성을 초래할 수 있습니다.

해결책: Covering Index

최적의 솔루션은 "covering index"를 생성하는 것입니다. "를 기본 테이블에 표시합니다. 이 인덱스에는 뷰 정의 쿼리에서 참조되는 열과 그룹화에 사용되는 모든 열이 포함되어야 합니다. 커버링 인덱스를 사용하면 MySQL이 기본 테이블 페이지에 액세스할 필요 없이 인덱스에서 직접 뷰 쿼리를 충족할 수 있습니다.

예를 들어, 최고 점수 테이블에 대해 제공된 예를 고려하면 커버링 인덱스는 다음과 같습니다.

CREATE INDEX highscores_IX3
ON highscores (player, happened_in, score);

이 인덱스가 있으면 MySQL은 뷰 쿼리에 이를 활용할 수 있습니다.

SELECT * FROM v_kobe_highscores WHERE happened_in = 2006;

이유 MySQL의 뷰는 문제가 될 수 있습니다

일부 다른 데이터베이스와 달리 MySQL은 외부 쿼리의 조건자를 뷰 쿼리로 "푸시"하지 않습니다. 대신 뷰 쿼리가 별도로 실행되어 뷰 정의의 모든 행을 포함하는 중간 테이블이 구체화됩니다. 그런 다음 외부 쿼리가 이 파생 테이블에 적용됩니다.

이 프로세스는 특히 대규모 테이블에 걸쳐 정의된 뷰의 경우 성능 저하로 이어질 수 있습니다.

대안: 인덱싱된 독립 실행형 쿼리

어떤 경우에는 뷰를 사용하는 것보다 독립형 쿼리를 실행하는 것이 더 효율적일 수 있습니다. 예:

SELECT player
     , MAX(score) AS highest_score
     , happened_in
 FROM highscores
WHERE player = 24
  AND happened_in = 2006
GROUP
   BY player
    , happened_in;

highscores 테이블에 적절한 포함 인덱스를 사용하면 이 쿼리는 뷰를 생성하고 구체화하는 오버헤드 없이 원하는 데이터를 효율적으로 검색할 수 있습니다.

위 내용은 MySQL 뷰는 효율적인 쿼리를 위해 인덱스를 활용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.