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에 대해서만 전략적으로 사용하는 것이 좋다.