MySQL ‐ Covering Index - thought-corner/Backend-PlayGround GitHub Wiki

MySQL - Covering Index

커버링 인덱스란?

  • 데이터베이스가 인덱스를 통해 데이터를 찾는 과정은 크게 두 단계로 나뉜다.
    • 인덱스 탐색 : 인덱스 트리를 타서 원하는 조건의 데이터를 찾고 그 데이터가 저장된 원본 테이블의 실제 주소를 알아낸다.
    • 테이블 접근 : 알아낸 주소를 가지고 원본 테이블로 찾아가서 나머지 필요한 컬럼의 데이터를 읽어온다.
  • 커버링 인덱스는 "테이블 접근"을 아예 생략하도록 만드는 인덱스이다.
  • 즉, 쿼리의 SELECT, WHERE, ORDER BY, GROUP BY 등에 사용되는 모든 컬럼이 이미 하나의 인덱스 안에 다 포함(Cover)되어 있는 상태를 말한다.
  • 원본 테이블에 갈 필요 없이 인덱스만 쓱 읽고 바로 결과를 반환하므로 디스크 I/O가 획기적으로 줄어들어 속도가 무척 빠르다.
CREATE TABLE stock_trade_history (
    id BIGINT AUTO_INCREMENT PRIMARY KEY,
    stock_code VARCHAR(20) NOT NULL,
    trade_date DATE NOT NULL,
    closing_price DECIMAL(10, 2),
    trade_volume BIGINT,
    
    INDEX idx_stock_trade (stock_code, trade_date)
);

트레이드오프

  • 커버링 인덱스를 만들겠다고 SELECT에 필요한 모든 컬럼을 인덱스에 다 때려 넣으면 안 된다.
  • 그렇게 되면 인덱스 자체가 거대해져서 메모리를 과도하게 차지하고, INSERT, UPDATE시 데이터를 써야 할 곳이 많아져 쓰기 성능이 심각하게 떨어진다.
  • 조회 빈도가 압도적으로 높고, 성능에 크리티컬한 핵심 API에 대해서만 전략적으로 사용하는 것이 좋다.