inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

mongoDB 기초부터 실무까지(feat. Node.js)

Pagination 원리

중간부분 개선 방법

294

살아남자

작성한 질문수 5

1

강의에서 페이징 중간부분도 개선가능하다고 하셨는데, 보통 어떤방법으로 개선하는지 짧게라도 알려주실 수 있을까요?

DBMS/RDBMS mongodb rest-api javascript aws nodejs 데이터 엔지니어링

답변 1

2

김시훈 (도도소프트)

살아남자님 안녕하세요 :)

생성 시간 순으로 정렬하고 pagination을 적용한다고 했을 때 예시로 알려드릴게요. 일단 _id는 기본으로 인덱스가 걸려 있고 해당 인덱스는 생성시간 순으로 나열이 되어 있어요. ObjectId에 timestamp가 포함되어 있기 때문이죠. 

일반적인 방법:

page1: model.find().skip(0).limit(10)

page2: model.find().skip(10).limit(10)

page3: model.find().skip(20).limit(10)

뒤로 갈수록 skip을 많이 해야되서 조금씩 느려지는건데요.

page1: model.find().imit(10)

page2: model.find({_id: { $gt: last_id }}).limit(10)

page3: model.find({_id: { $gt: last_id }}).limit(10)

이런식으로 하게 되면 skip을 할 필요가 없어지죠. 전 페이지의 마지막 문서의 _id를 GET API에 같이 보내주는거에요. 그러면 인덱스로 빠르게 탐색하고 다음 페이지의 문서들을 빠르게 호출할 수 있게 됩니다.

option usecreateindex is not supported 오류 나면은

0

146

1

Schemaless 특성을 재생시 검은화면이 나와요

0

240

1

user 내장 시 ref 필드 필요성

0

239

1

await 관련해서 질문드릴게 있습니다!!

0

292

2

섹션6의 3번째 강의 faker파일이 어디있나요?

0

308

1

$elemMatch 질문이 있습니다.

0

245

1

DB 업데이트에 실패했을 상황에서 대처는 어떻게 할 수 있나요.

2

765

2

블로그에 user 데이터를 추가하는 방법에 대해서

0

237

1

blog 데이터 생성시 user 관련 오류

0

351

1

age 예외 처리를 별도로 하신 이유가 궁금합니다.

2

301

2

delete 메소드가 많은 이유가 궁금합니다.

0

181

1

unique validation 처리

0

296

1

updateMany에서 user._id를 못찾는 상황

1

396

1

find() 가 리턴하는 instance member

1

431

3

몽고 db를 백업방법을 부탁합니다.

0

603

1

인덱스 생성시점

0

712

1

$pull 문법에 대한 질문

0

359

1

comment의 id가 생성되는 시점

1

301

1

리팩토링 강의에서 라우터 리팩토링 전개연산자(...)

1

315

1

session.abortTransaction()에 대한 실제 예시 문의

0

287

1

섹션9 Computed Fields 강의에서, 다음 강의 가기 전 빠진부분

-1

407

1

faker 패키지 취약성 이슈

1

485

1

라우터 리팩토링

0

341

1

섹션4 진행중, mongoose 질문

0

309

1