home강의 홈으로
Section 4. MySQL 더 깊이 알아가기
Lesson 3. 인덱스 - 검색을 빠르게!

인덱스

  • 특정 컬럼(들)에 대한 목차 생성 - 검색 가속화
  • 테이블 내용변경(추가, 수정, 삭제)시 시간 더 소모


1. 인덱스 사용하기

-- 인덱스 생성 ALTER TABLE `mydatabase`.`businesses` ADD INDEX index_biz_name (business_name); -- 다중 컬럼 인덱스 ALTER TABLE menus ADD INDEX index_name_cal (menu_name, kilocalories); -- 인덱스 조회 SHOW INDEX FROM businesses; -- 인덱스 삭제 ALTER TABLE businesses DROP INDEX index_biz_name;

2. 인덱스를 사용하기 적합한 곳

  • 데이터의 변경이 잦지 않은 테이블
  • WHERE, ORDER BY 에 자주 사용되는 컬럼
  • JOIN에 사용되는 컬럼
  • Cardinality가 높은 컬럼 = 중복도가 낮은 컬럼 (B-Tree 경우)

    • 성별: 부적합, 이름: 적합


3. 인덱스의 종류

1. B-Tree 인덱스

  • 기본(default) 인덱스
  • Cardinality가 높은 컬럼에 적합

2. Full-Text 인덱스

ALTER TABLE ratings ADD FULLTEXT INDEX index_full_text (comment); SELECT * FROM ratings WHERE MATCH(comment) AGAINST ('괜찮은데');
  • 다수의 단어 등을 포함하는 컬럼에서 단어 및 구문을 검색하기 위함
  • 데이터를 일정 단위로 분할하여 인덱싱
  • *InnoDB, MyISM에서만 사용 가능
  • CHAR, VARCHAR, TEXT 컬럼에만 적용 가능
  • Full-Text Index 문서 링크

3. Hash 인덱스

  • 일치 여부만 확인 (= 가능, >, >=, <, <=, LIKE 등 불가)
  • 인덱스 크기가 작고 검색이 매우 빠름
  • MEMORY, NDB 엔진에서만 사용가능

    • InnoDB 엔진에서는 내부적으로 Adoptive Hash Index 구현


4. 비트맵 인덱스

  • Cardinality가 낮은 컬럼에 적합
  • MySQL에는 없음

🤔얄코에게 질문하기질문은 반.드.시 이리로 보내주세요! ( 강의사이트 질문기능 ✖ )

강의에서 이해가 안 되거나 실습상 문제가 있는 부분,
설명이 잘못되었거나 미흡한 부분을 메일로 알려주세요!

답변드린 뒤 필요할 경우 본 페이지에
관련 내용을 추가/수정하도록 하겠습니다.

이메일 주소
yalco@yalco.kr
메일 제목 (반드시 아래 제목을 붙여넣어주세요!)
[질문] 조금 더 깊은 MySQL 4-3

🛑질문 전 필독!!

  • 구글링을 먼저 해 주세요. 들어오는 질문의 절반 이상은 구글에 검색해 보면 1분 이내로 답을 찾을 수 있는 내용들입니다.
  • 오류 메시지가 있을 경우 이를 구글에 복붙해서 검색해보면 대부분 짧은 시간 내 해결방법을 찾을 수 있습니다.
  • 강의 페이지에 추가사항 등 놓친 부분이 없는지 확인해주세요. 자주 들어오는 질문은 페이지에 추가사항으로 업데이트됩니다.
  • "유료파트의 강의페이지는 어디 있나요?" - 각 영상의 시작부분 검은 화면마다 해당 챕터의 강의페이지 링크가 있습니다.
  • 질문을 보내주실 때는 문제가 어떻게 발생했고 어떤 상황인지 등을 구체적으로 적어주세요. 스크린샷을 첨부해주시면 더욱 좋습니다.
🌏 Why not change the world?