2장 인덱스 기본

친절한 SQL 튜닝 2장

Index Range Scan

B* 인덱스의 가장 일반적인 탐색 방식이다. 루트에서 리프까지 수직적으로 탐색한 후에 필요한 범위만 스캔한다. 인덱스 선두 컬럼을 가공하지 않은 상태로 조건절에 사용해야 한다.

CREATE INDEX idx_user_age ON user(age);
SELECT * FROM user WHERE age BETWEEN 25 AND 35;

Index Full Scan

인덱스를 처음부터 끝까지 모두 읽는 방식이다. 대용량 테이블에서 Index Range 스캔을 할 수 없을 때, 차선책으로 선택한다. 수직적 탐색 없이 리프를 처음부터 끝까지 수평으로 탐색한다. 옵티마이저가 index full scan, table full scan 의 효율성을 비교해 선택하는데 주로 조회할 레코드가 적은 경우에 index full scan을 선택한다.

CREATE INDEX idx_user_age ON user(age);
SELECT age FROM user;

Index Unique Scan

unique 인덱스를 = 조건으로 탐색하는 경우 수직적으로 탐색한다. 데이터를 한 건만 찾고 끝낸다. pk로 조회할 때도 이 스캔 방식을 사용한다.

CREATE UNIQUE INDEX idx_user_email ON user(email);
SELECT * FROM user WHERE email = 'signature@hyeon.com';

Index Skip Scan

오라클의 새로운 스캔 방식이다. 인덱스 선두 컬럼이 조건절에 없어도 후행 컬럼 조건만으로 선두 컬럼을 반복 스캔하며 인덱스를 재활용하는 방식이다.

CREATE INDEX idx_user_dept_age ON user(dept, age);
SELECT * FROM user WHERE age = 30; // 후행 컬럼 조건이 있는 경우 (선두는 없어야 함)

Index Fast Full Scan

인덱스 트리 구조를 무시하고 물리적으로 저장된 순서대로 multiblock I/O 방식으로 스캔한다. 전체 인덱스를 정렬 없이, 병렬 가능하게, 빠르게 블록 단위로 읽는 방식이다.

CREATE INDEX idx_user_age_name ON user(age, name);
SELECT age, name FROM user;

Index Range Scan Descending

Index Range Scan을 역순으로 읽는 방식이다. max 값을 구할 때도 사용한다.

CREATE INDEX idx_user_age ON user(age);
SELECT * FROM user WHERE age >= 20 ORDER BY age DESC;

Last updated