Index Range Scan은 인덱스를 사용하여 특정 범위 내의 데이터를 검색하는 방식입니다.BETWEEN, <, >, LIKE 'A%', IN 등의 연산자를 사용할 때 발생하며, 여러 개의 결과를 반환할 가능성이 있습니다.
Index Range Scan은 SQL튜닝의 꽃으로, 보통 Index Range Scan을 태우기 위해 튜닝을 하는 경우가 많습니다. SQL의 WHERE조건의 첫 번째 조건절을(선두컬럼) 가공한다면 (가공 : A컬럼이면 substr(A,2)라던지.. to_number(A) 등 순수하게 A를 그대로 사용하지 않는 경우) Index Range Scan을 타지 않습니다. (인덱스 구조 공부 필요). 반대로 인덱스의 선두컬럼을 가공하지 않고 첫번째 조건절에 그대로 사용한다면 Index Range Scan을 태울 수 있다는 얘기가 됩니다.
✔ 범위 검색(연속된 값 검색) 시 사용
✔ 여러 개의 행을 반환할 가능성이 높음
✔ B-Tree 인덱스에서 루트 → 리프 노드까지 탐색 후, 조건에 맞는 데이터까지 순차적으로 읽음
✔ 순차적인 인덱스 검색이므로 성능이 우수함
BETWEEN, <, >, LIKE 'A%', IN)를 사용한 검색✅ 범위 검색 (BETWEEN, <, >)
SELECT * FROM EMP WHERE EMP_ID BETWEEN 1000 AND 2000; 🔍 실행 계획 (EXPLAIN PLAN)
INDEX RANGE SCAN (EMP_IDX) ✔ EMP_ID가 인덱스 컬럼이라면 범위 내 값을 검색할 때 Index Range Scan 발생
✅ 보다 작은 값 검색 (<)
SELECT * FROM EMP WHERE EMP_ID < 1000; ✔ 1000 이하의 값을 찾기 위해 인덱스에서 처음부터 검색
✅ 보다 큰 값 검색 (>)
SELECT * FROM EMP WHERE EMP_ID > 1000; ✔ 1000 이후의 값을 찾기 위해 인덱스의 특정 지점에서 끝까지 검색
✅ LIKE 연산자가 접두어 검색(LIKE 'A%')일 경우
SELECT * FROM EMP WHERE EMP_NAME LIKE 'A%'; 🔍 실행 계획:
INDEX RANGE SCAN (EMP_NAME_IDX) ✔ ‘A%’는 인덱스 정렬 순서를 유지하면서 검색할 수 있어 Index Range Scan 사용 가능
❌ 와일드카드가 앞에 있는 경우 (LIKE '%A')는 Index Range Scan 사용 불가
SELECT * FROM EMP WHERE EMP_NAME LIKE '%A'; 🔍 실행 계획:
FULL TABLE SCAN ✔ 인덱스를 사용할 수 없어 Full Table Scan 발생
IN 연산자에서 Index Range Scan 발생✅ IN 연산자 사용
SELECT * FROM EMP WHERE EMP_ID IN (1001, 1002, 1003); 🔍 실행 계획:
INDEX RANGE SCAN (EMP_IDX) ✔ 각각의 EMP_ID 값을 찾아야 하므로 범위 검색처럼 처리됨
✅ INDEX 힌트 사용
SELECT /*+ INDEX(EMP EMP_IDX) */ *
FROM EMP
WHERE EMP_ID BETWEEN 1000 AND 2000; 🔍 실행 계획:
INDEX RANGE SCAN (EMP_IDX) ✔ 옵티마이저가 다른 실행 계획을 선택하지 않도록 강제 적용
❌ 정확한 값(Unique Value)을 조회하는 경우
SELECT * FROM EMP WHERE EMP_ID = 1001; 🔍 실행 계획:
INDEX UNIQUE SCAN (EMP_PK) ✔ 단일 값 검색은 Index Unique Scan이 발생
❌ LIKE 연산자에서 %가 앞에 있는 경우
SELECT * FROM EMP WHERE EMP_NAME LIKE '%A'; 🔍 실행 계획:
FULL TABLE SCAN ✔ 전체 문자열을 검사해야 하므로 Index Range Scan이 아닌 Full Table Scan 발생
| 스캔 유형 | 설명 | 사용 조건 |
|---|---|---|
| Index Unique Scan | PK, UNIQUE 인덱스에서 단일 값 검색 | WHERE 컬럼 = 값 |
| Index Range Scan | 범위 검색 (BETWEEN, <, >) | WHERE 컬럼 > 값 또는 LIKE 'A%' |
| Index Full Scan | 인덱스 전체 검색 | 정렬이 필요하거나 인덱스 자체만 읽을 때 |
| Index Fast Full Scan | 멀티 블록 읽기 사용 | 인덱스 전체를 빠르게 읽을 때 |
| Index Skip Scan | 복합 인덱스의 일부 키만 사용 | 선행 컬럼 없이 후행 컬럼을 검색할 때 |
🔹 범위 검색(BETWEEN, <, >, LIKE 'A%')을 효과적으로 사용하면 Index Range Scan을 유도할 수 있음
🔹 불필요한 Full Table Scan을 피하고, 인덱스 검색이 효율적으로 이루어지는지 실행 계획을 확인
🔹 INDEX(TABLE_NAME INDEX_NAME) 힌트를 사용하여 옵티마이저가 Index Range Scan을 사용하도록 유도할 수 있음
✅ Index Range Scan은 범위 검색 (BETWEEN, <, >, LIKE 'A%', IN)을 수행할 때 발생하며, 여러 개의 행을 반환할 가능성이 있음
✅ 정확한 값 검색은 Index Unique Scan이 발생하지만, 범위 검색이 포함되면 Index Range Scan이 발생함.
✅ 옵티마이저가 다른 실행 계획을 선택하지 않도록 INDEX 힌트를 사용하여 강제 적용 가능 🚀
코스피 8% 폭락, 서킷브레이커 발동, SK텔레콤 Claude AI 차단까지. 한국의 AI 레버리지 버블이 단 하루…
SNS 사진 1장으로 30초 만에 딥페이크 영상이 완성됩니다. 당신의 얼굴이 이미 범죄에 악용되고 있을 수…
SNS 사진 1장으로 30초 만에 딥페이크 영상이 완성됩니다. 당신의 얼굴이 이미 범죄에 악용되고 있을 수…
달러/원 환율이 급등하는 이유와 실생활 영향을 정리했습니다. 지금 당장 활용할 수 있는 환전·투자 대응 전략까지…
미래에셋·미래에셋벤처투자·미래에셋생명이 동반 급등한 이유는 스페이스X 상장 기대감입니다. 세 회사가 스페이스X와 어떻게 연결되어 있는지 상세히 분석했습니다.
스페이스X 상장이 계속 미뤄지는 진짜 이유를 파헤쳤습니다. 화성 계획, 스타링크 분리, 국방 계약... 머스크가 절대…