使用skip和top进行OData分页 - 如何知道没有更多数据?

Tsc*_*eck 4 odata

我有 OData 源,它实现$skip$top参数。返回了 x 个实体。比如说,我只有 250 个实体。然后我尝试像这样进行分页:

https://example.com/EntitySet?$top=30&$skip=220
Run Code Online (Sandbox Code Playgroud)

如果我的跳过超过了实体总数,我最终会从服务中超时。

是否有参数或数据会通知我没有更多项目?是否有可以/应该在 OData 端实现的东西,它会返回而不是超时?

Yor*_*ram 6

对于 OData 2.0 和 OData 3.0 协议:您应该使用: $inlinecount=allpages

http://services.odata.org/OData/OData.svc/Products$inlinecount=allpages&$top=5&$format=json

标识前 5 个产品条目并包括产品条目总数的计数。

对于 OData 4.0,您可以阅读响应中嵌入的nextLink注释。(请参阅此处的示例)

4.5.5 odata.nextLink 注释 odata.nextLink 注释表明响应只是请求的实体集合或实体引用集合的子集。它包含一个 URL,允许检索请求集合的下一个子集。


GWi*_*Wam 5

如果您添加&$count=true到您的 uri,服务将在响应中包含总计数。json 响应将包含一个"@odata.count"属性。该属性表示实体的总数。

这样您就可以检查是否已收到所有实体。