Background Image
질의작성
2015.06.04 19:56

SQL튜닝 - 인덱스 활용 사례

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

○ 개요

작성 한 SQL문 내에서, 쿼리에서 사용하는 특정 컬럼에 인덱스가 있음에도 인덱스 스캔을 하지 않는 경우가 있을 것이다.

이러한 경우, SQL문 변경/튜닝을 통해서 성능을 향상 시키는 방법을 간단한 예제를 통해서 확인한다. 


○ 인덱스란?

 - 데이터베이스 분야에 있어서 테이블에 대한 동작의 속도를 높여주는 자료 구조를 일컫는다. 

   인덱스는 테이블 내의 1개의 컬럼, 혹은 여러 개의 컬럼을 이용하여 생성될 수 있다. 

   고속의 검색 동작뿐만 아니라 레코드 접근과 관련 효율적인 순서 매김 동작에 대한 기초를 제공한다. 

   인덱스를 저장하는 데 필요한 디스크 공간은 보통 테이블을 저장하는 데 필요한 디스크 공간보다 작다. 

   (왜냐하면 보통 인덱스는 키-필드만 갖고 있고, 테이블의 다른 세부 항목들은 갖고 있지 않기 때문이다.) 



○ 사례1 : NOT, <>, !=의 부정형 연산은 인덱스 사용이 불가함으로 >= 연산으로 변경하여,name 인덱스를 활용하도록 개선

 - 튜닝 전

   SELECT code, NAME 

   FROM athlete 

   WHERE NAME IS NOT null            


 - 튜닝 후

   SELECT code, NAME 

   FROM athlete 

   WHERE NAME >=''                      




○ 사례2 : game_date 컬럼에 TO_CHAR 함수를 사용하여 인덱스 사용이 불가.  2000년 1월부터 12월까지 조회하도록 변경

    ※ 조회 대상이 되는 컬럼에 함수를 사용 할 경우, 해당 컬럼에 인덱스가 있어도 활용이 불가

 - 튜닝 전

CREATE INDEX i_game_game_date ON game(game_date);


SELECT athlete_code 

FROM game 

WHERE TO_CHAR(game_date,'yyyy')='2000'                               



 - 튜닝 후

SELECT athlete_code 

FROM game 

WHERE game_date BETWEEN TO_DATE('200001','yyyymm') AND TO_DATE('200012','yyyymm')           





○ 사례3 : Index가 nation_code, name로 있고, 조회조건을 name으로 검색 할 경우에 인덱스 사용이 불가함으로, 인덱스 생성 순서를 name, nation_code 순서로 변경하여 생성

 - 튜닝 전

CREATE INDEX idx01_athlete ON 

athlete(nation_code, name);


SELECT *

FROM athlete

WHERE NAME LIKE 'Fernandez%'           



 - 튜닝 후

CREATE INDEX idx01_athlete ON 

athlete(name, nation_code);


SELECT *

FROM athlete

WHERE NAME LIKE 'Fernandez%'           




○ 사례4 : 한개의 테이블에 하나의 인덱스만 선택하여 실행 함으로, 단일 인덱스 여러 개의 구조 보다는 multi-column index 생성하여 쿼리 성능 향상

 - 튜닝 전

select * from game where stadium_code=‘30115' and nation_code=‘KOR'; 


create index i_game_1 on game(stadium_code);

create index i_game_2 on game(nation_code);                                               



 - 튜닝 후

select * from game where stadium_code=‘30115' and nation_code=‘KOR';           


create index i_game_1 on game(stadium_code, nation_code);          





○ 쿼리 튜닝 시 고려사항 

- Where절에서 자주 사용되는 컬럼에는 인덱스 추가 고려

- 인덱스를 많이 생성하는 것은 INSERT/UPDATE/DELETE 성능 저하의 원인이 될 수 있음.

- 동일한 값을 가지는 레코드가 적은 컬럼에 인덱스를 설정

- 인덱스 scan이 Full Table scan보다 항상 빠르지는 않다.






List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
219 질의작성 여러개의 컬럼을 하나로 묶어주는 함수 CONCAT_WS 사용방법 엄기호 2019.01.29 7229
218 CUBRID 매니저 여러 버전의 CUBRID에 CUBRID Manager로 연결하는 방법 일동차렷? 2009.03.14 15355
217 질의작성 시스템 테이블을 이용한 인덱스 생성 구문 만들기 janus 2009.12.02 15143
216 운영관리 시스템 부하가 많지 않음에도 불구하고 질의 수행이 느린 경우 THP 기능 설정 확인 및 해제 진우진 2015.12.16 7526
215 질의작성 스키마에서 한글 사용하는 방법 file seongjoon 2009.04.14 15362
214 질의작성 스키마 및 인덱스 선언에 따른 최대 용량 산정을 위한 ROW SIZE 확인 성진 2016.03.21 4179
213 질의작성 세부내역과 소계를 한개의 쿼리문장으로 수행하는 SQL 권호일 2012.03.31 14092
212 운영관리 산술 연산 결과를 피젯수 또는 젯수의 자리 수에 맞춰 보자. 성진 2016.03.01 4816
211 운영관리 브로커와 DB 간 연결 테스트 박동윤 2015.12.29 4934
210 운영관리 브로커 상태를 확인할 때 status 의미 시난 2009.11.27 16552
209 운영관리 브로커 동적 파라미터 변경 방법 정만영 2015.08.13 7566
208 운영관리 백업파일을 이용하여 데이터베이스가 없는 다른 서버에서 복구하는 방법 admin 2008.11.21 22044
207 질의작성 문자(char, varchar)로 설계한 날짜데이타 검증하기 권호일 2012.04.27 17829
206 질의작성 문자 코드셋(UTF-8, EUC-KR) 사용시 CUBRID 는? 남재우 2010.01.01 22398
205 질의작성 모든 필드에 하나 이상 중복 값 찾기 정만영 2010.04.27 21588
204 운영관리 막무가내 DBA의 DISK 장애 대처 정병주 2009.04.16 20444
203 운영관리 리눅스 쉘프롬프트 상에서 질의 바로 수행하기 Prototype 2009.12.10 13640
202 운영관리 디비와 테이블 문자셋이 다른 경우 처리 방법 이용미 2015.06.03 15802
201 질의작성 두 datetime 연산결과를 "?일 ?시:?분:?초"로 표시하기 권호일 2016.05.18 6368
200 운영관리 데이터베이스를 다른 머신으로 옮기는 방법 admin 2008.11.21 27666
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

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