Index Range Scan 개요

Index Range Scan인덱스를 사용하여 특정 범위 내의 데이터를 검색하는 방식입니다.
BETWEEN, <, >, LIKE 'A%', IN 등의 연산자를 사용할 때 발생하며, 여러 개의 결과를 반환할 가능성이 있습니다.

1️⃣ 특징

범위 검색(연속된 값 검색) 시 사용
여러 개의 행을 반환할 가능성이 높음
B-Tree 인덱스에서 루트 → 리프 노드까지 탐색 후, 조건에 맞는 데이터까지 순차적으로 읽음
순차적인 인덱스 검색이므로 성능이 우수함

2️⃣ 사용 조건

  • 범위 연산자 (BETWEEN, <, >, LIKE 'A%', IN)를 사용한 검색
  • 인덱스의 일부 키만 사용하는 경우
  • 결과가 다수의 행을 반환할 가능성이 있는 경우

3️⃣ 쿼리 예제

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

범위 검색 (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 이후의 값을 찾기 위해 인덱스의 특정 지점에서 끝까지 검색

(2) LIKE 검색에서 Index Range Scan

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 발생

(3) IN 연산자에서 Index Range Scan 발생

IN 연산자 사용

SELECT * FROM EMP WHERE EMP_ID IN (1001, 1002, 1003);

🔍 실행 계획:

INDEX RANGE SCAN (EMP_IDX)

각각의 EMP_ID 값을 찾아야 하므로 범위 검색처럼 처리됨

(4) Index Range Scan을 강제하는 힌트(Query Hint)

INDEX 힌트 사용

SELECT /*+ INDEX(EMP EMP_IDX) */ * 
FROM EMP
WHERE EMP_ID BETWEEN 1000 AND 2000;

🔍 실행 계획:

INDEX RANGE SCAN (EMP_IDX)

옵티마이저가 다른 실행 계획을 선택하지 않도록 강제 적용

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

정확한 값(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 발생

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

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

6️⃣ 최적화 전략

🔹 범위 검색(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 힌트를 사용하여 강제 적용 가능 🚀

zerg96

Recent Posts

충격! 코스피 8% 폭락에 SK텔레콤 AI 차단까지 – 한국의 AI 도박이 터졌다

코스피 8% 폭락, 서킷브레이커 발동, SK텔레콤 Claude AI 차단까지. 한국의 AI 레버리지 버블이 단 하루…

2주 ago

당신 얼굴이 이미 쓰이고 있다… AI 딥페이크 범죄, 생각보다 훨씬 심각합니다

SNS 사진 1장으로 30초 만에 딥페이크 영상이 완성됩니다. 당신의 얼굴이 이미 범죄에 악용되고 있을 수…

3주 ago

당신 얼굴이 이미 쓰이고 있다 — AI 딥페이크 범죄, 생각보다 훨씬 심각합니다

SNS 사진 1장으로 30초 만에 딥페이크 영상이 완성됩니다. 당신의 얼굴이 이미 범죄에 악용되고 있을 수…

3주 ago

달러·원 환율 급등, 지금 당신이 꼭 알아야 할 것들

달러/원 환율이 급등하는 이유와 실생활 영향을 정리했습니다. 지금 당장 활용할 수 있는 환전·투자 대응 전략까지…

3주 ago

미래에셋·미래에셋벤처투자·미래에셋생명 동반 급등, 스페이스X와 무슨 관계?

미래에셋·미래에셋벤처투자·미래에셋생명이 동반 급등한 이유는 스페이스X 상장 기대감입니다. 세 회사가 스페이스X와 어떻게 연결되어 있는지 상세히 분석했습니다.

3주 ago

스페이스X 상장 D-데이? 일론 머스크가 절대 말 안 하는 진짜 이유

스페이스X 상장이 계속 미뤄지는 진짜 이유를 파헤쳤습니다. 화성 계획, 스타링크 분리, 국방 계약... 머스크가 절대…

3주 ago