If the pagesize is 10 and pageNumber
is 0, for the given condition, if I I get 50 documents from mongodb, then total_documents
should be 50 and msList
should have the details of 1st 10 documents(DTO's)(since the pageNumber
is 0 i.e. pagination).
Query query = new Query();
List<Criteria> criteria = new ArrayList<>();
criteria.add(Criteria.where("di.ai").in(new ArrayList<>(Arrays.asList("123"))));
query.addCriteria(new Criteria().andOperator(criteria.toArray(new Criteria[criteria.size()])));
Long total_documents = this.mongoTemplate.count(query, NSDTO.class, MONGODB_MESSAGE_COLLECTION);
Pageable pageable = PageRequest.of((pageNumber - 1), pageSize);
query.with(pageable);
List<NSDTO> nsList= this.mongoTemplate.find(query, NSDTO.class, MONGODB_MESSAGE_COLLECTION);"
I am able to achieve this functionality using the above code, but the problem here is we are making mongodb calls 2 times.
Would it be possible to achieve the same functionality using only one mongodb call?
Could someone please help on this regard.
It is possible to achieve the pagination in one call with
$facet
. Just be reminded not to have too large page size since it would fail due to 16MB MongoDB document size limit.Mongo Playground