[Hint]ACCESS 경로를 변경하는 힌트(INDEX_COMBINE):namespace prefix
= o />
이 힌트는 비트맵 인덱스에 대해서만 적용 가능한 힌트 입니다. 예를 들어 EMP 테이블에 대해ename에 bidx_emp_ename이라는 비트맵 인덱스, deptno에 bidx_emp_deptno라는 비트맵 인덱스가 생성되어 있다고 할
때 아래와 같이 INDEX_COMBINE이라는 힌트와 테이블 명을 인자로 주게 되면
적절한 비트맵 인덱스를 조합하여 실행 계획을 만들어 내게 됩니다.
구로디지털
오엔제이프로그래밍실무교육센터
SELECT
*
FROM EMP E
WHERE ename = ‘SMITH’
AND deptno = 10;
Execution Plan
-------------------------------------------------------------------
SELECT STATEMENT
Optimizer=CHOOSE
TABLE ACCESS (BY INDEX ROWID) OF ‘EMP’
BITMAP CONVERSION (TO
ROWIDS)
BITMAP AND
BITMAP INDEX (SINGLE VALUE) OF ‘bidx_emp_ename’
BITMAP INDEX (SINGLE VALUE) OF ‘bidx_emp_deptno’
뮬론 힌트 사용시 다음과 같이 테이블명과 비트맵 인덱스 명을 줘도 관계 없습니다.
또한 INDEX_COMBINE 대신 INDEX 힌트를 이용하여 비트맵 인덱스를 줘도 되지만 비트맵 인덱스라는 경우
알리기 위해 INDEX_COMBINE을 사용하는 것이 좋습니다.
[실습]
- 실습을 위한 예제 테이블 및 데이터는 아래 링크에서
확인 바랍니다.
myemp1 : 1000만건
myemp1_old : 100만건
mydept : 5건
테스트환경 : oracle 11g
SQL> conn
scott/tiger
연결되었습니다.
SQL> set
autotrace on explain
SQL> set
linesize 120
SQL> set
timing on
SQL> create bitmap index bidx_myemp1_deptno on
myemp1(deptno);
인덱스가 생성되었습니다.
SQL> create bitmap index bidx_myemp1_sal on
myemp1(sal);
인덱스가 생성되었습니다.
SQL>
SELECT
2
count(ename)
3 FROM
MYEMP1 E
4 WHERE
deptno = 1
5 AND sal
> 800000;
COUNT(ENAME)
------------
1200000
경 과: 00:00:08.84
-----------------------------------------------------------------------------
| Id |
Operation | Name | Rows | Bytes | Cost (%CPU)| Time
|
-----------------------------------------------------------------------------
| 0 | SELECT
STATEMENT | | 1 | 20 | 16990 (1)| 00:03:24
|
| 1 | SORT
AGGREGATE | | 1 | 20 | |
|
|* 2 | TABLE ACCESS
FULL| MYEMP1 | 1200K| 22M| 16990 (1)| 00:03:24 |
-----------------------------------------------------------------------------
SQL>
SELECT
count(ename)
FROM
MYEMP1 E
WHERE
deptno = 1
AND sal
> 800000
;
COUNT(ENAME)
------------
1200000
경 과: 00:00:10.74
-------------------------------------------------------------------------------------------------
| Id |
Operation | Name | Rows | Bytes | Cost
(%CPU)| Time |
-------------------------------------------------------------------------------------------------
| 0 | SELECT
STATEMENT | | 1 | 20 | 124K (1)|
00:24:59 |
| 1 | SORT
AGGREGATE | | 1 | 20 |
| |
| 2 | TABLE ACCESS
BY INDEX ROWID | MYEMP1 | 1200K| 22M| 124K (1)| 00:24:59
|
| 3 | BITMAP
CONVERSION TO ROWIDS| | | | |
|
| 4 | BITMAP
AND | | | | |
|
|* 5 | BITMAP
INDEX SINGLE VALUE| BIDX_MYEMP1_DEPTNO | | | |
|
| 6 | BITMAP
MERGE | | | | |
|
|* 7 | BITMAP
INDEX RANGE SCAN | BIDX_MYEMP1_SAL | | | |
|
비트맵 인덱스를 사용 안 했을 때 성능이 더 좋다.
댓글 없음:
댓글 쓰기