DB
[mysql] index / 인덱스
김중앙
2017. 1. 3. 10:40
MySQL인덱스 기초
● 특정 컬럼 값이 가지고 있는 열을 빠르게 검색하기 위하여 사용
● MySQL의 경우 B-TREE 가 사용됨
● 오라클이나 MSSQL의 경우 여러가지 타입이 존재함
● 종류에는 PRIMARY KEY, UNIQUE, INDEX, FULL TEXT가 있다.(FULL TEXT의 경우 MyISAM 에서만 사용가능)
■ 인덱스 사용 목적
- where 절에 매치하는 열을 빠르게 검색하기 위하여
- 불 필요한 열을 고려 대상에서 빠르게 제거하기 위하여
- JOIN시 다른 테이블에서 빠르게 필요한 열을 추출하기 위하여
- 특정 index의 컬럼의 MIN이나 MAX값을 찾기 위하여
■ 인덱스를 사용하는 경우
- 데이터의 양이 많고 검색이 빈번히 이루어 지는 경우
- 인덱스를 걸고자 하는 필드의 값의 종류가 다양한 경우
■ 생성
- 인덱스를 만들게 되면 MySQL에서 TABLE을 생성할시 만들어지는 3개의 파일 (MYD, MYI, FRM)중 MYI파일에 해당 컬럼을 색인화 하여 새롭게 저장(물론 인덱스를 사용하지 않을 경우 이 파일은 비어 있다.)
- 사용자가 SELECT를 할 경우 인덱싱이 되어 있는 컬럼 정보를 이용할 경우 TABLE로 보내는 것이 아니라 MYI파일에 바로 검색하여 빠르게 검색
■ 단점
- MYI파일에 새롭게 작성하기 떄문에 그만큼 디스크의 용량이 증가한다
- UPDATE, INSERT의 속도가 떨어진다 ( 매번 table과 table index를 모두 체크해야 하므로 속도가 느려진다 )
■ 주의사항
- index필드에 null이 존재할 수 없다
- 한 테이블에 5개 이상의 인덱스는 권장하지 않는다
- 인덱스가 된 컬럼을 가지고 조건에서 연산을 하면 무의미한 짓이다
■ 인덱스를 걸었지만 무의미 한 경우
- not <> 는 인덱스가 무의미하다
- like도 무의함
- where에서 연산하는 경우
- 문자열의 경우 150 바이트 초과시
http://rrhh234cm.tistory.com/302 - 펌
index 추가
alter table 테이블명 add index 인덱스명(`컬럼명`); |
index 확인
show index from 테이블명; |
index 제거
alter table 테이블명 drop index 해당인덱스명(해당컬럼명) |