In Spring Data, we have PagingAndSortingRepository
which inherits from CrudRepository
. In reactive Spring Data, we only have
ReactiveSortingRepository
which inherits from ReactiveCrudRepository
.
How could we make pagination in a reactive way ?
Will we able to make this in future with ReactivePagingAndSortingRepository
for instance?
Reactive Spring Data MongoDB repositories do not provide paging in the sense of paging how it's designed for imperative repositories. Imperative paging requires additional details while fetching a page. In particular:
Both aspects do not fit to the notion of efficient, non-blocking resource usage. Waiting until all records are received (to determine the first chunk of paging details) would remove a huge part of the benefits you get by reactive data access. Additionally, executing a count query is rather expensive, and increases the lag until you're able to process data.
You can still fetch chunks of data yourself by passing a Pageable
(PageRequest
) to repository query methods:
interface ReactivePersonRepository extends Repository<Person, Long> {
Flux<Person> findByFirstnameOrderByLastname(String firstname, Pageable pageable);
}
Spring Data will apply pagination to the query by translating Pageable
to LIMIT
and OFFSET
.
References: