오라클 Index Unique Scan

Index Unique Scan고유한(UNIQUE) 인덱스Primary Key(PK) 인덱스를 이용하여 단 하나의 값을 빠르게 조회할 때 사용되는 인덱스 스캔 방식입니다. 참고로 오라클에서 Primary Key(PK) 인덱스는 테이블 생성 시 자동으로 만들어집니다.

1️⃣ 특징

항상 하나의 결과(또는 존재하지 않음)를 반환
고유한 값(UNIQUE, PRIMARY KEY) 조건일 때만 작동
가장 빠른 인덱스 검색 방법 중 하나
B-Tree 인덱스에서 루트 → 리프 노드까지 최단 경로 탐색

2️⃣ 사용 조건

  • WHERE 조건이 고유 인덱스(UNIQUE INDEX) 또는 PRIMARY KEY를 완전하게 지정한 경우.
  • 단일 행을 조회할 때 사용됨.
  • 인덱스의 전체 키 컬럼을 포함하는 검색이어야 함.

3️⃣ 쿼리 예제

(1) 기본적인 Index Unique Scan 예제

EMP_IDPRIMARY KEY 또는 UNIQUE INDEX로 설정된 경우

SELECT * FROM EMP WHERE EMP_ID = 1001;

🔍 실행 계획 (EXPLAIN PLAN)

INDEX UNIQUE SCAN (EMP_PK)

EMP_ID는 PK(Primary Key)이므로 Index Unique Scan 발생

(2) 복합 인덱스(Composite Index)에서 Index Unique Scan 발생

(DEPT_ID, EMP_ID) 복합 인덱스에서 완전한 키 검색

SELECT * FROM EMP WHERE DEPT_ID = 10 AND EMP_ID = 1001;

🔍 실행 계획:

INDEX UNIQUE SCAN (EMP_DEPT_IDX)

두 개의 키 컬럼을 모두 지정했기 때문에 Index Unique Scan 발생

(3) Index Unique Scan을 강제하는 힌트(Query Hint)

INDEX 힌트를 사용하여 인덱스 사용을 강제할 수 있음

SELECT /*+ INDEX(EMP EMP_PK) */ * FROM EMP WHERE EMP_ID = 1001;

🔍 실행 계획:

INDEX UNIQUE SCAN (EMP_PK)

✔ 옵티마이저가 다른 실행 계획을 선택하지 않도록 강제 인덱스 힌트 추가

4️⃣ Index Unique Scan이 발생하지 않는 경우

부분 키 검색

SELECT * FROM EMP WHERE EMP_ID > 1000;

🔍 실행 계획:

INDEX RANGE SCAN (EMP_PK)

범위 검색이므로 Index Range Scan 발생

복합 인덱스에서 일부 키만 검색

SELECT * FROM EMP WHERE EMP_ID = 1001;

(단, EMP_DEPT_IDX(DEPT_ID, EMP_ID)가 있을 때) 🔍 실행 계획:

INDEX SKIP SCAN (EMP_DEPT_IDX)

복합 인덱스에서 선행 컬럼(DEPT_ID)이 없으므로 Index Skip Scan 발생

5️⃣ Index Unique Scan vs. 다른 Index Scan과 비교

스캔 유형설명사용 조건
Index Unique ScanPK, UNIQUE 인덱스에서 단일 값 검색WHERE 컬럼 = 값
Index Range Scan범위 검색 (BETWEEN, <, >)WHERE 컬럼 > 값
Index Full Scan인덱스 전체 검색정렬이 필요하거나 인덱스 자체만 읽을 때
Index Fast Full Scan멀티 블록 읽기 사용인덱스 전체를 빠르게 읽을 때
Index Skip Scan복합 인덱스의 일부 키만 사용선행 컬럼 없이 후행 컬럼을 검색할 때

6️⃣ 최적화 전략

🔹 Primary Key와 Unique Index는 Index Unique Scan을 자동으로 사용
🔹 WHERE 조건에서 인덱스의 모든 키 컬럼을 포함하면 Index Unique Scan 가능
🔹 불필요한 범위 검색을 피하고 단일 조회를 유도하면 성능 최적화 가능

📌 정리

Index Unique Scan가장 빠른 인덱스 검색 방식이며, UNIQUE 또는 PRIMARY KEY를 통한 단일 행 조회에서 발생합니다.
완전한 키 값을 검색하는 경우에만 작동하며, 범위 검색(BETWEEN, <, >) 또는 일부 키 검색은 Index Range Scan으로 변경됩니다.
INDEX(TABLE_NAME INDEX_NAME) 힌트를 사용하여 강제 적용 가능하며, 옵티마이저가 다른 실행 계획을 선택하는 것을 방지할 수 있습니다. 🚀

Leave a Comment