Background Image
질의작성
2009.04.17 04:38

LIKE 검색에서 INDEX_SCAN사용 하기

조회 수 21809 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
대부분 LIKE를 '%'를 이용하여 검색을 많이 합니다.
쓰는데야 문제는 없겠지만 LIKE라는 걸 잘모르면 성능에 큰영향을 줄수 있습니다.
CUBRID demodb를 가지고 예를 들겠습니다.

우선  "create index game_idx on game(nation_code);"을 수행하여 nation_code의 인덱스를 생성합니다.
LIKE검색에서 인덱스가 타지 않는 경우
CUBRID Manager의 질의편집기를 이용하여 아래질의를 수행합니다.
SELECT * FROM game  WHERE nation_code like '%US%';
수행 후 Ctrl+l 을 누르면 질의 플랜에서  sscan(Sequence Scan)을 하고 있다는 것을 볼 수 있습니다.
즉, nation_code에 대하여 인덱스를 만들었지만 game테이블의 모든 nation_code에 대하여 'US'단어가 들어간 모든 데이터를 찾고 있습니다.


성능에 큰영항을 주겠죠?
결론적으로 LIKE연산을 할때 비교되는 대상의 앞에 '%"가 먼저 오면 INDEX를 사용할 수 없습니다.

너무 당연한 거지만 아래와 같이 '%'를 제거하여 INDEX-SCAN을 하는지 보겠습니다.
SELECT * FROM game WHERE nation_code LIKE 'US%';
수행 후 동일하게 Ctrl+l을 눌러 쿼리플랜을 보면, 아래와 같이 INDEX-SCAN을 하는 것을 알 수 있습니다.


여기서 좀더 고차원적인 문제가 생긴다면,
아마도 어쩔수 없이 '%XXX%'이런 형식을 써야 하는 경우일 것입니다.
예를 들어, USA혹은 US를 모르겠고 단지 중간에 S가 들어 가는 건 알고 있고 인덱스를 태우고 싶다고 한다면
편법(?)을 쓴다면 인덱스를 사용할 수 있도록 불필요한 조건을 부여하는 것입니다.
SELECT * FROM game WHERE nation_code >= '' and nation_code LIKE '%S%';

이 방법은 I-SCAN을 사용하는 예이므로 성능을 비교할 것이 못됩니다.;;
다만 복합적인 질의문 사용에 있어 보다 효율적으로 INDEX-SCAN을 하여 성능을 개선하고자 함입니다.



List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
14 질의작성 CUBRID 2008에서 ' 사용하기. file seongjoon 2009.06.16 13315
13 질의작성 오라클 바이딩 변수와 큐브리드 인터프리터 변수를 사용한 경로 표현식 정만영 2009.06.09 13483
» 질의작성 LIKE 검색에서 INDEX_SCAN사용 하기 file janus 2009.04.17 21809
11 질의작성 스키마에서 한글 사용하는 방법 file seongjoon 2009.04.14 15362
10 질의작성 데이터 값 작은 따옴표(') 넣기 정만영 2009.03.20 23813
9 질의작성 테이블 데이터 복사 하기 정만영 2009.03.14 22301
8 질의작성 컬럼 사이즈 변경 방법 정만영 2009.03.14 24337
7 질의작성 다중 row를 하나의 column에 넣기 정만영 2009.03.13 20089
6 질의작성 요일 값을 반환 받을 수 있는 질의 형태 정만영 2009.03.13 17107
5 질의작성 데이터 필드의 타입 변경하기 admin 2008.11.21 18420
4 질의작성 예약어를 테이블명이나 컬럼명으로 사용시 admin 2008.11.21 37427
3 질의작성 중복된 데이터에 대하여 일련번호를 붙이는 방법 admin 2008.11.21 17362
2 질의작성 중복된 데이터를 1개만 남기고 지우는 방법 admin 2008.11.21 17306
1 질의작성 select 결과중 몇개만 가져오는 방법 admin 2008.11.21 19917
Board Pagination Prev 1 2 3 4 Next
/ 4

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales