Azure Table查询:System.InvalidOperationException:'已经存在与此命令关联的打开的DataReader,必须首先关闭它。'

问题描述 投票:0回答:1

我在执行表时偶尔遇到以下错误

System.InvalidOperationException:'已经有与此命令关联的打开的DataReader,必须先关闭它。'

private CloudTable table;

    public AzureTableManager(string _CloudTableName)
    {
        if (string.IsNullOrEmpty(_CloudTableName))
        {
            throw new ArgumentNullException("Table", "Table Name can't be empty");
        }
        try
        {
            string ConnectionString = PrimariusOMS.Properties.Settings.Default.AzureTableStorage.ToString();
            CloudStorageAccount storageAccount = CloudStorageAccount.Parse(ConnectionString);
            CloudTableClient tableClient = storageAccount.CreateCloudTableClient();

            table = tableClient.GetTableReference(_CloudTableName);
            table.CreateIfNotExists();
        }
        catch (StorageException StorageExceptionObj)
        {
            throw StorageExceptionObj;
        }
        catch (Exception ExceptionObj)
        {
            throw ExceptionObj;
        }
    }

    public List<T> RetrieveEntity<T>(string TenantName, string Query = null) where T : TableEntity, new()
    {
TableQuery<T> DataTableQuery = new TableQuery<T>();
            if (!String.IsNullOrEmpty(Query))
            {
                Query += " and PartitionKey eq '" + TenantName + "'";
            }
            else { Query = "PartitionKey eq '" + TenantName + "'"; }

            DataTableQuery = new TableQuery<T>().Where(Query);
            IEnumerable<T> IDataList = table.ExecuteQuery(DataTableQuery);
            List<T> DataList = new List<T>();
            foreach (var singleData in IDataList)
                DataList.Add(singleData);
            return DataList;
}

这里返回错误:

IEnumerable<T> IDataList = table.ExecuteQuery(DataTableQuery);

这是我的示例通话:

List<AzureTableManager.DTTConfig> dtt = TableManagerObj.RetrieveEntity<AzureTableManager.DTTConfig>(tenantID, "RowKey eq 'Mass WhatIf'");

在SQL连接中,可通过使用USING块或确保阅读器已关闭来克服此问题。我在这里如何处理?

c# azure-table-storage azure-tablequery
1个回答
0
投票

您可能会尝试将您的参考文献更新为最新版本的WindowsAzure.Storage

在新版本中,CloudTable类不再包含ExecuteQuery方法。相反,它具有ExecuteQueryAsyncExecuteQuerySegmentedAsync方法。

此代码对我来说获取数据有用:

public static async Task<List<T>> ExecuteQueryToListAsync<T>(this CloudTable table, TableQuery<T> query) where T : ITableEntity, new()
{
    var result = new List<T>();

    TableContinuationToken token = null;
    do
    {
        TableQuerySegment<T> seg = await table.ExecuteQuerySegmentedAsync(query, token);
        token = seg.ContinuationToken;
        result.AddRange(seg);
    }
    while (token != null);

    return result;
}
© www.soinside.com 2019 - 2024. All rights reserved.