什么决定/控制从 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 设置,我无法影响单次获取返回的数量。