사전 준비

image.png

create table member_tb(
id int primary key auto_increment,
gender char(1),
nickname varchar(20),
age int,
money int
);

desc member_tb;
DELIMITER $$

DROP PROCEDURE IF EXISTS insertDummyData$$

CREATE PROCEDURE insertDummyData()
BEGIN
DECLARE i INT DEFAULT 1;
WHILE i <= 1000000 DO
IF mod(i,2) = 1 THEN
INSERT INTO member_tb(gender, nickname, age, money)
VALUES('M', concat('닉네임', i), FLOOR(1 + RAND() * 60),FLOOR(10000 + RAND() *
100000));
ELSE
INSERT INTO member_tb(gender, nickname, age, money)
VALUES('F', concat('닉네임', i), FLOOR(1 + RAND() * 60),FLOOR(10000 + RAND() *
100000));
END IF;
SET i = i + 1;
END WHILE;
END$$

DELIMITER $$

CALL insertDummyData;

1. 인덱스 사용

select *
from member_tb;

select *
from member_tb
where nickname = '닉네임7'; -- 0.219s

select *
from member_tb
where id = 7; -- 0.0s

2. CREATE INDEX

-- 인덱스 제작 조건 1. 비즈니스 상 해당 컬럼을 조회하는 일이 자주 발생해야 함
-- 인덱스 제작 조건 2. 중복 데이터가 전체 데이터의 15% 이내일 때
create index nickname_idx on member_tb (nickname);

-- 왜 닉네임7을 조회하면 안되는가? - 캐싱되어있음 (LRU(Least Recently Used) 알고리즘)
select * from member_tb where nickname = '닉네임9'; -- 0.0s

3. INDEX의 특징

  1. UK (Unique Key) : Indexing이 빨라 탐색 시간이 대폭 감소
-- 인덱스 삭제 & UK 생성
drop index nickname_idx on member_tb;
alter table member_tb add constraint uk_nickname unique(nickname);

select * from member_tb where nickname = '닉네임10'; -- 0.0s