Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- 1450
- Path Variable
- Query String
- kafka connect
- 페이지네이션 최적화
- reflog
- code --no-sandbox
- API 설계
- 참조무결성
- Cannot add or update a child row: a foreign key constraint fails
- kafka-connect
- 문자열 검증
- Invalid character found in method name
- 1452
- debezium
- programmers
- 제약 조건
- kafkaconnect
- jdbc connector
- foreign key constraint fails
- git rebase -i
- Cannot delete or update a parent row: a foreign key constraint fails
- 23000
- constraint fails
- Late row lookup
- Git
- 페이지네이션
- git reflog
- event loop
- Pagination Optimization
Archives
- Today
- Total
Kawaii_Jordy
[Pagination] limit, offset 사용법 및 Late Row Lookup을 통한 Pagination 최적화 본문
취준/DB
[Pagination] limit, offset 사용법 및 Late Row Lookup을 통한 Pagination 최적화
Kawaii_Jordy 2021. 5. 10. 10:38Mysql 에서 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의 경우는 이렇게 색인 된 값을 이용해야 소요시간이 최소화 된다.
'취준 > DB' 카테고리의 다른 글
[Mysql, Maria] TIMEDIFF with option (0) | 2021.06.03 |
---|---|
[Sequelize] bind (0) | 2021.06.02 |
[Sequelize] transaction (0) | 2021.05.26 |
[Sequlize] nodejs sequelize raw-queries (0) | 2021.05.12 |
[참조무결성] (1452): Cannot add or update a child row: a foreign key constraint fails 해결 (0) | 2021.05.08 |
Comments