如何解决什么决定/控制从 Azure 表的 ExecuteQuerySegmented(Async) 返回的记录数?
决定返回多少条记录 ExecuteQuerySegmentedAsync 的因素是什么?
我的情况是,返回记录的数量以前是 ~500,现在是 ~35。
编辑
我的代码是:
TableContinuationToken token = null;
do
{
TableQuerySegment<X> queryResult = table.ExecuteQuerySegmented(query,token);
if (queryResult.Any())
{
OnDataReceived(queryResult);
}
token = queryResult.ContinuationToken;
} while (token != null);
queryResult.Count()
是可靠的 ~35。
private static TableQuery<X> GetQuery(string partitionKey,string startStr,string endStr)
{
// Create filter for greater than start and less than end
var startEpochQuery = TableQuery.GenerateFilterCondition("RowKey",QueryComparisons.GreaterThanorEqual,startStr);
var endEpochQuery = TableQuery.GenerateFilterCondition("RowKey",QueryComparisons.LessthanorEqual,endStr;
var epochQuery = TableQuery.CombineFilters(startEpochQuery,TableOperators.And,endEpochQuery);
// Query for partition key
var partitionQuery = TableQuery.GenerateFilterCondition("PartitionKey",QueryComparisons.Equal,partitionKey);
// Combining the queries
var combined = TableQuery.CombineFilters(partitionQuery,epochQuery);
return new TableQuery<X>().Where(combined);
}
这导致 query.FilterString
为 (PartitionKey eq 'key_here') and ((RowKey ge '1596240000') and (RowKey le '1612915200'))
解决方法
返回记录的大小似乎会影响返回记录的数量。
在选择非常小的列时,查询结果包含1000条记录,随着有效载荷增长的记录滴数。
尝试使用 TableRequestOptions 设置,我无法影响单次获取返回的数量。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。