针对这个问题,需要使用 Continuation token 的方式对 Cosmos 数据库进行分页操作。以下是示例代码:
public async Task> GetItemsAsync(string continuationToken)
{
const int PageSize = 10;
var query = this.container.GetItemQueryIterator- (
new QueryDefinition("SELECT * FROM c ORDER BY c.id"),
continuationToken: continuationToken,
requestOptions: new QueryRequestOptions { MaxItemCount = PageSize });
return await query.ReadNextAsync();
}
在上面的示例中,我们使用 GetItemQueryIterator() 方法来获取 Cosmos 中的数据。该方法将会返回一个迭代器,该迭代器允许您获取特定数量的项。 当使用 Continuation token 来检索数据时,在前一次查询中返回的结果中包含 Continuation token。 此时,需要将该 Continuation token 传递到下一次查询中,以便从上一个查询结束的位置继续检索数据。
通过使用 Continuation token 的方式进行分页操作,你就能够避免在每次请求中使用较大的 Limit 和上一次检索的 Offset(位移量)这两种方式,此方式可能会使查询时间变慢并且会增加 Cosmos 的资源消耗。