Skip to main content
Skip table of contents

Pagination

This mode allows retrieving data in smaller chunks over multiple HTTP requests. On the first request, instead of only fetching the first batch of rows, CData Virtuality fetches the whole result set and stores it in a cache. When the next batch is requested from the HTTP client, data is served from the cache instead of recalculating the result set of the actual query. To identify subsequent batches, the REST API returns an additional HTTP header requestid as well as pointers to the previous and next pages.

Please note that for the first request, the pagination mode can be activated only when providing the pagination=TRUE parameter. For subsequent requests, it is enough to provide only the requestId parameter with a particular cursor identifier.

Example 1

XML
POST http://<cdatavirtuality-server-address>:8080/rest/api/query?pagination=true&limit=3&offset=3

Body (application/json):

XML
{ "sql": "SELECT * FROM SYS.Tables" }

STATUS 200

[
    ["datavirtuality","SYS","Keys","Table",null,true,false,"tid:2cb59cfd55db-0023a214-00000040",-1,null,true,false,4],
    ["datavirtuality","SYS","ProcedureParams","Table",null,true,false,"tid:2cb59cfd55db-ab347619-0000004c",-1,null,true,false,5],
    ["datavirtuality","SYS","Procedures","Table",null,true,false,"tid:2cb59cfd55db-8f29b420-0000005d",-1,null,true,false,6]
]

Headers in response:

limit = 3

offset = 3

nextPage = http://localhost:8080/rest/api/query?requestId=767913&limit=3&offset=6

prevPage = http://localhost:8080/rest/api/query?requestId=767913&limit=3&offset=0

requestId = 767913

Example 2

XML
POST http://<cdatavirtuality-server-address>:8080/rest/api/query?requestId=767913&limit=3&offset=6

Body (application/json):

XML
{ "sql": "SELECT * FROM SYS.Tables" }

STATUS 200

[
    ["datavirtuality","SYS","Properties","Table",null,true,false,"tid:2cb59cfd55db-3f9f6953-00000066",-1,null,true,false,7],
    ["datavirtuality","SYS","ReferenceKeyColumns","Table",null,true,false,"tid:2cb59cfd55db-aa92fa09-0000006c",-1,null,true,false,8],
    ["datavirtuality","SYS","Schemas","Table",null,true,false,"tid:2cb59cfd55db-d57e16d2-0000007b",-1,null,true,false,9]
]

Headers in response:

limit = 3

offset = 6

nextPage = http://localhost:8080/rest/api/query?requestId=767913&limit=3&offset=9

prevPage = http://localhost:8080/rest/api/query?requestId=767913&limit=3&offset=3

requestId = 767913

Example 3

Pagination with source endpoint:

XML
GET http://<cdatavirtuality-server-address>:8080/rest/api/source?pagination=true&limit=2&offset=0

Body (application/json):

XML
STATUS 200

[{"Name":"INFORMATION_SCHEMA"},{"Name":"SYS"}]

Headers in response:

limit = 2

offset = 0

nextPage = http://localhost:8080/rest/api/source?requestId=667476&limit=2&offset=2&array=false&headers=false

prevPage = http://localhost:8080/rest/api/source?requestId=667476&limit=2&array=false&headers=false

requestId = 667476

Pagination support for source endpoints (data source-based requests) is available since v4.10

Example 4

In case of an illegal query, status 400 with an explanatory message will be returned, as illustrated by this final example:

XML
POST http://<cdatavirtuality-server-address>:8080/rest/api/query?pagination=true

Body (application/json):

XML
{ "sql": "NOT SQL" }

STATUS 400

{
  "title": "Something is wrong",
  "description": "Error while parsing query: Encountered \"NOT\" at line 1, column 1.\rWas expecting one of:\r    \"begin\" ...\r    \"{\" ...\r    \"create\" ...\r    \"alter\" ...\r    \"with\" ...\r    \"select\" ...\r    \"values\" ...\r    \"table\" ...\r    \"(\" ...",
  "hint": null
}
JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.