인프런 커뮤니티 질문&답변

이화평님의 프로필 이미지
이화평

작성한 질문수

스프링 배치

DB - Cursor & Paging 이해

Fetch와 Cursor의 순서?

작성

·

471

0

[DB - Cursor & Paging 이해] 강의에서 보여주신 장표를 보면 cursot가 먼저 움직이고 fetch를 통해 application으로 매핑된 데이터(객체)를 넘겨주는 것처럼 표현되어있는데요.

fetch size에 의해서 DB --> 메모리로 데이터가 적재된 후, 그 결과집합을 순차적으로 cursor를 통해 접근하는걸로 알고있습니다.

즉, fetch size는 DB에서 메모리로 데이터를 적재할 크기이고 그 데이터 셋을 처음부터 cursor를 통해 접근하는게 맞지않나 싶어서 질문드립니다. 제가 반대로 알고 있을 수 있지만...

답변 1

0

정수원님의 프로필 이미지
정수원
지식공유자

네 맞습니다.

fetch size 를 주게 되면 그 크기 만큼 데이터를 메모리로 가지고 와서 순차적으로 참조하게 됩니다.

강의에서는 cursor 방식의 흐름을 설명한 것입니다.

즉 paging 방식은 블록단위로 페이지를 나누어서 데이터를 처리하는 것에 비해 cursor 방식은 데이터를 스트리밍 방식으로 계속 참조한다는 것을 설명하기 위한 것인데 fetch size 를 주게 되면 동일한 스트리밍 방식은 맞지만 데이터를 한개씩이 아닌 일정한 크기만큼 가지고 와서 처리하고 있습니다.

질문하신 내용으로 이해하시면 됩니다.

이화평님의 프로필 이미지
이화평

작성한 질문수

질문하기