IT/SQL
MySQL[13] - INDEX
올빼밋.
2022. 6. 2. 21:31
728x90
목차
1. INDEX
1. INDEX
인덱스(INDEX) 개념
- 검색을 빠르게 하기 위한 자료구조(주로 B트리 계열)
- 기본키는 자동으로 인덱스설정
- 인덱스 ON/OFF를 통해 검색속도 차이 체감(대량의 데이터일수록 큰 영향)
- 조인(JOIN)시에도 영향을 줌
DBMS의 기초
정렬
- 빠른 검색을 위해서는 데이터가 반드시 정렬(Sorting)되어 있어야 함
- 정렬 되어 있지 않다면 평균적으로 전체 데이터의 절반 필요(최선: 1, 최약: N, 평균:N/2)
- 정렬되면 있을 경우 데이터를 빠른 시간 안에 찾을 수 있음 O(NlogN)-O(N^2)
- 퀵 정렬/힙정렬 계열이 주로 사용됨
인덱스(Index)
- 인덱스 종류
- 데이터 추가/수정/삭제할 때마다 정렬/인덱스 업데이트가 일어남
이진탐색(Binary Search)
- 데이터를 정렬 후 “test” 단어를 검색하는 경우
- 데이터가 추가/삭제/변경될 때마다 한가운데/왼쪽 가운데/오른쪽 가운데값 등을 미리 계산해 놓음
B-트리(B-Tree)
- 이진 검색과 유사하지만 한 번에 비교를 2번(a, b : a < b)
- B-트리 계열이 이진검색 계열보다 빠름
- 데이터가 추가/삭제/변경 될 때마다 a, b 값을 업데이트
인덱스(INDEX) 설정
- 인덱스 추가/삭제
create database sampleDB;
create table BusinessCard(Name Varchar(255), Address Varchar(255), Telephone Varchar(255));
insert into BusinessCard values (‘Bob’, ‘Seocho-dong 123’, ‘123-4567’);
insert into BusinessCard values (‘Sam’, ‘Sindang-dong 456’, 321-4321’);
create index BusinessCard_Telephone_index on BusinessCard(Telephone);
728x90