아래와 같이 두 개 이상의 필드를 이용해서 인덱스를 구성하는 것을 복합 인덱스(Composite index)라고 한다. 인덱스는 검색키와 주소의 쌍으로 구분되며 이를 인덱스 엔트리(Index Entry)라 부르는데, 복합인덱스는 검색키 N개와 주소의 쌍이 인덱스 엔트리가 되는 것이다.
검색키 1-1 |
검색키 2-1 |
레코드 주소 |
검색키 1-2 |
검색키 2-2 |
레코드 주소 |
검색키 1-3 |
검색키 2-3 |
레코드 주소 |
이 때, 인덱스는 대소관계에 의해 검색키1을 우선 정렬하고 검색키1에 대해여 검색키2를 정렬하는 방식으로 구성된다. 예를 들어, 아래 좌측과 같은 테이블이 있고 A와 B컬럼을 복합 인덱스로 하면, 아래 우측과 같이 인덱스가 만들어 지는 것이다.
A 컬럼 |
B 컬럼 |
C 컬럼 |
|
A 컬럼 검색키 |
B 컬럼 검색키 |
레코드 주소 |
1001 |
1 |
A |
|
1001 |
1 |
|
1001 |
2 |
B |
|
1001 |
2 |
|
1002 |
4 |
A |
|
1002 |
2 |
|
1002 |
2 |
C |
|
1002 |
4 |
|
1003 |
2 |
A |
|
1003 |
2 |
|
A컬럼과 B컬럼의 인덱스가 각각 만들어져 있다면, select * from 테이블 where A컬럼='1001' and B컬럼='2' 라는 질의를 날렸을 때, A컬럼='1001'의 조건으로 참조된 결과와 B컬럼='2'의 조건으로 참조된 결과를 비교하여 중첩된 레코드를 찾을 것이다. 하지만 복합 인덱스로 구성했을 경우에는 두 조건을 만족하는 레코드를 하나의 인덱스로 처리할 수 있어서 효율적이다.
또한 select B컬럼 값 from 테이블 where A컬럼='1001' 처럼 원본 데이터에 접근하지 않고도 복합 인덱스내에서 바로 질의 처리가 가능해지는 경우도 있다.
단, 필드의 순서에 따라 인덱스 효과가 달라지기 때문에 주의를 요한다.
예를 들어,
select * from 테이블 where A컬럼 = '1001' and B컬럼 > '2' 와
select * from 테이블 where A컬럼 > '1001' and B컬럼 = '2'라는 질의를 날린다고 해보자.
첫 번째 질의는 A컬럼 키 1001을 찾은 뒤 제한 된 B 컬럼의 검색키를 검색하면되지만, 두 번째 질의는 A컬럼 > '1001'을 만족하는 검색키를 모두 검색하면서 B컬럼='2' 조건을 조회하기 때문에 효율적으로 동작하지 않는다. 따라서 두번째 질의를 잘 처리하기 위해서는 (B컬럼, A컬럼)의 순서로 구성된 필드 집합으로 복합 인덱스를 생성해야 한다.
결국 복합 인덱스를 만들 때는 자주 사용되는 질의 유형을 사전에 분석하여 결정해야 하는 것이다.
'DB' 카테고리의 다른 글
PL/SQL 조건, 반복 제어문 (0) | 2017.08.05 |
---|---|
PL/SQL 구조와 변수 (0) | 2017.08.03 |
PL/SQL 시작하기 (0) | 2017.07.18 |
해쉬 인덱스 (0) | 2017.06.06 |
B+ 트리 인덱스 (0) | 2017.06.06 |