Implement automatic pagination for search results exceeding 1000 items#16
Merged
sirbastiano merged 4 commits intomainfrom Jan 18, 2026
Merged
Conversation
Co-authored-by: sirbastiano <71963566+sirbastiano@users.noreply.github.com>
Copilot
AI
changed the title
[WIP] Coming soon: Implement a count option for search results more than 1000. In case the count is more than 1000, you will have to lunch more queries with the pagin mechanism:
paginating through the results like here::
https://catalogue.dataspace.coperni...
Implement automatic pagination for search results exceeding 1000 items
Aug 25, 2025
… e modifica i parametri di ricerca nel notebook
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR implements automatic pagination functionality for the
CopernicusDataSearcherclass to handle large datasets that exceed the OData API's 1000 result limit per request.Problem
Previously, the searcher could only retrieve a maximum of 1000 results per query, even when the total available results exceeded this limit. Users had no way to access the complete dataset when searches returned more than 1000 products.
Solution
Added automatic pagination that triggers when
count=Trueand the total result count exceeds thetopparameter. The implementation:@odata.count>top, automatically initiates pagination$skipparameter: Makes sequential requests with$skip=1000,$skip=2000, etc.Usage
Implementation Details
The solution adds a
_execute_paginated_query()helper method that:topparameter as the page size (default: 1000)$skipvaluesExample paginated requests generated:
Testing
Added comprehensive test suite covering:
$skipparameter usageAll existing functionality remains unchanged when
count=False(default behavior).💡 You can make Copilot smarter by setting up custom instructions, customizing its development environment and configuring Model Context Protocol (MCP) servers. Learn more Copilot coding agent tips in the docs.