OrientDB supports pagination natively. Pagination doesn't consume server side resources because no cursors are used. Only RecordIDs are used as pointers to the physical position in the cluster.
There are 2 ways to achieve pagination:
The first and simpler way to do pagination is to use the SKIP
/LIMIT
approach. This is the slower way because OrientDB repeats the query and just skips the first X records from the result.
Syntax:
SELECT FROM <target> [WHERE ...] SKIP <records-to-skip> LIMIT <max-records>
Where:
Example
This method is faster than the SKIP
-LIMIT
because OrientDB will begin the scan from the starting RID. OrientDB can seek the first record in about O(1) time. The downside is that it's more complex to use.
The trick here is to execute the query multiple times setting the LIMIT
as the page size and using the greater than >
operator against @rid
. The lower-rid is the starting point to search, for example #10:300
.
Syntax:
SELECT FROM <target> WHERE @rid > <lower-rid> ... [LIMIT <max-records>]
Where:
In this way, OrientDB will start to scan the cluster from the given position lower-rid + 1. After the first call, the lower-rid will be the rid of the last record returned by the previous call. To scan the cluster from the beginning, use #-1:-1
as lower-rid .
database.open("admin", "admin");
final OSQLSynchQuery<ODocument> query = new OSQLSynchQuery<ODocument>("select from Customer where @rid > ? LIMIT 20");
ORID last = new ORecordId();
List<ODocument> resultset = database.query(query, last);
while (!resultset.isEmpty()) {
last = resultset.get(resultset.size() - 1).getIdentity();
resultset = database.query(query, last);
}
database.close();
In order to simplify the pagination, the OSQLSynchQuery
object (usually used in queries) keeps track of the current page and, if executed multiple times, it advances page to page automatically without using the >
operator.
Example:
OSQLSynchQuery<ODocument> query = new OSQLSynchQuery<ODocument>("select from Customer LIMIT 20");
for (List<ODocument> resultset = database.query(query); !resultset.isEmpty(); resultset = database.query(query)) {
...
}
This is the faster way to achieve pagination with large clusters.
If you've defined an index, you can use it to paginate results. An example is to get all the names next to Jay
limiting it to 20:
Collection<ODocument> indexEntries = (Collection<ODocument>) index.getEntriesMajor("Jay", true, 20);