오라클(Oracle)에서 Index Scan은 인덱스를 활용하여 데이터를 조회하는 방식이며, 다양한 방식으로 수행될 수 있습니다. 주요 Index Scan의 종류는 다음과 같습니다.
WHERE
절에서 완전한 키 값을 검색하는 경우SELECT * FROM EMP WHERE EMP_ID = 1001;
INDEX UNIQUE SCAN (INDEX_NAME)
BETWEEN
, LIKE 'ABC%'
, <
, >
, IN
조건이 포함된 경우 발생.SELECT * FROM EMP WHERE EMP_ID BETWEEN 1000 AND 2000; SELECT * FROM EMP WHERE NAME LIKE 'A%';
INDEX RANGE SCAN (INDEX_NAME)
FULL TABLE SCAN
보다 효율적일 수 있음.WHERE
절 없이 ORDER BY가 인덱스 순서와 일치하는 경우.SELECT EMP_ID FROM EMP ORDER BY EMP_ID;
INDEX FULL SCAN (INDEX_NAME)
INDEX FULL SCAN
과 다르게 인덱스 데이터를 병렬로 읽을 수 있음.SELECT
절에서 인덱스에 포함된 컬럼만 사용하는 경우 (INDEX ONLY SCAN
최적화).WHERE
절 없이 모든 인덱스 데이터를 읽어야 하는 경우.SELECT EMP_ID FROM EMP;
INDEX FAST FULL SCAN (INDEX_NAME)
-- 복합 인덱스 (DEPT_ID, EMP_NAME) 존재 SELECT * FROM EMP WHERE EMP_NAME = 'John';
INDEX SKIP SCAN (INDEX_NAME)
AND
조건을 만족하는 데이터를 찾음.WHERE
조건이 인덱스 컬럼들을 동시에 포함할 때.SELECT * FROM EMP WHERE EMP_ID = 1001 AND DEPT_ID = 10;
INDEX JOIN SCAN
ORDER BY column DESC
조건에서 발생.SELECT * FROM EMP ORDER BY EMP_ID DESC;
INDEX RANGE SCAN DESCENDING (INDEX_NAME)
Index Scan 유형 | 특징 | 사용 조건 |
---|---|---|
Index Unique Scan | 고유(UNIQUE) 값 조회 | WHERE PK = ? |
Index Range Scan | 특정 범위 조회 | BETWEEN , < , LIKE |
Index Full Scan | 인덱스 전체 스캔 | ORDER BY 정렬 시 |
Index Fast Full Scan | 병렬 인덱스 전체 스캔 | 인덱스 컬럼만 조회 |
Index Skip Scan | 선행 컬럼 없이 후행 컬럼 조회 | 복합 인덱스 후행 컬럼 사용 |
Index Join Scan | 여러 인덱스를 조합하여 조회 | 다중 인덱스 활용 |
Index Range Scan Descending | 인덱스 역순 검색 | ORDER BY DESC |
각 Index Scan은 쿼리 조건과 인덱스 구조에 따라 다르게 동작하므로, EXPLAIN PLAN
또는 AUTOTRACE
를 통해 실행 계획을 확인하는 것이 중요합니다. 🚀
Index Scan 유형 | 사용되는 힌트(Query Hint) | 설명 |
---|---|---|
Index Unique Scan | INDEX(TABLE_NAME INDEX_NAME) | 유일한(PK, UNIQUE) 값을 조회할 때 사용. |
Index Range Scan | INDEX(TABLE_NAME INDEX_NAME) | 범위 검색 (BETWEEN , < , > , LIKE 'A%' ) 수행. |
Index Full Scan | INDEX_FFS(TABLE_NAME INDEX_NAME) | 인덱스를 전체 검색, 테이블 조회 최소화. |
Index Fast Full Scan | INDEX_FFS(TABLE_NAME INDEX_NAME) | 멀티 블록 읽기를 활용하여 인덱스 전체를 빠르게 스캔. |
Index Skip Scan | INDEX_SS(TABLE_NAME INDEX_NAME) | 복합 인덱스의 선행 컬럼 없이 후행 컬럼만 검색 가능. |
Index Join Scan | INDEX_JOIN(TABLE_NAME INDEX1 INDEX2) | 두 개 이상의 단일 컬럼 인덱스를 조합하여 테이블 조회를 줄임. |
Index Range Scan Descending | INDEX_DESC(TABLE_NAME INDEX_NAME) | 인덱스를 역순(Descending)으로 읽음. |
📌 추가 참고 사항
INDEX_FFS
와 INDEX_SS
는 성능 최적화에 중요한 역할을 하므로, 특정 상황에서 활용 가능성을 고려해야 합니다.INDEX_JOIN
은 복합 인덱스를 생성하지 않고도 다중 인덱스를 활용하는 방법입니다.오늘은 AI 생태계에 혁신적인 변화를 가져올 것으로 예상되는 MCP(Model Context Protocol)에 대해 상세히 알아보겠습니다. 2024년…
1. TPM이란? TPM(Trusted Platform Module)은 국제 표준 기반의 보안 하드웨어 칩으로, 컴퓨터나 디지털 장비 내에서…
시즌2, 기대했는데... 실망도 두 배!두뇌싸움을 기대했는데, 전략도 없는 자기들만의 감정에 따른 편가르기, 정치싸움이 되어 버린…
BPF(Berkeley Packet Filter) 도어는 해커가 관리자 몰래 뒷문을 새로 만든 것입니다.해커가 명령을 내려 특정 데이터들을 뒷문을…
1. IPC의 개념과 목적 1.1 IPC란 무엇인가? IPC (Inter-Process Communication)는 운영체제 내의 서로 독립적인 프로세스…