Kawaii_Jordy

[Pagination] limit, offset 사용법 및 Late Row Lookup을 통한 Pagination 최적화 본문

취준/DB

[Pagination] limit, offset 사용법 및 Late Row Lookup을 통한 Pagination 최적화

Kawaii_Jordy 2021. 5. 10. 10:38

Mysql 에서 limit, offset 사용 방법

RoomLog 라는 테이블이 20개의 열을 가지고 있다고 가정하고 결과를 살펴보겠습니다.

 

 

1) LIMIT : Select query 실행 시, 출력하고 싶은 열의 갯수를 나타냄

SELECT * FROM 테이블명 LIMIT 숫자;

 

SELECT * FROM RoomLog LIMIT 5;

 

 

2) OFFSET : Select query 실행 시, 출력을 시작하고 싶은 열의 첫번째 순서를 나타냄

SELECT * FROM 테이블명 LIMIT 숫자1 OFFSET 숫자2; (첫 번째 부터 출력하기 위해서는 OFFSET이 0 이어야 함)

 

SELECT * FROM RoomLog LIMIT 5 OFFSET 10;

 

 

SELECT * FROM RoomLog LIMIT 5 OFFSET 0;

 

 

Mysql 에서 Late Row Lookup을 통한 Pagination 최적화

SELECT *
FROM 테이블 AS p
JOIN ( SELECT 키값
         FROM 테이블
         LIMIT 300000, 10) AS q
ON p.키 = q.키;
SELECT *
FROM RoomLog AS p
JOIN ( SELECT idx
         FROM RoomLog
         LIMIT 300000, 0) AS q
ON p.idx = q.idx;

Full Index Scan한 후, Index(Unique Key)를 기준으로 INNET JOIN(Nested Loop) 을 시행하여 테이블의 값을 가져오는 방법이다. 이런 방법을 Late row lookup 이라고 한다. 20개 정도의 select는 굳이 join을 쓰지 않아도 되지만 몇 만개 정도의 큰 DB의 경우는 이렇게 색인 된 값을 이용해야 소요시간이 최소화 된다.

Comments