1

我正在尝试根据我的范围过滤器删除 Azure 表实体。我在这里尝试的只是删除较旧的记录。

我能够根据我的范围搜索条件获得正确的实体。

TableQuery<Tables> rangeQuery = new TableQuery<Tables>().Where(
    TableQuery.CombineFilters(
    TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "DeleteTablename"),
    TableOperators.And,
    TableQuery.GenerateFilterConditionForDate("StartedOn", QueryComparisons.LessThan, DateTime.Now.Add(new TimeSpan(0, -60, 0)))));

    foreach(Tables rows in logTable.ExecuteQuery(rangeQuery)) {
        log.Info($"{rows.PartitionKey}, {rows.RowKey}\t{rows.FinishedOn}\t{rows.Timestamp}");
    }
    //till here it works
    TableResult retrievedResult = logTable.ExecuteQuery(rangeQuery);
    Tables deleteEntity = (Tables)retrievedResult.Result;

收到以下错误

无法将类型“System.Collections.Generic.IEnumerable”隐式转换为“Microsoft.WindowsAzure.Storage.Table.TableResult”timertest

无法将类型“Microsoft.WindowsAzure.Storage.Table.TableResult”转换为“timertest.Tables”timertest

笔记:

  • timertest是我的namespace
  • Tables是一个类,它扩展TableEntity类以在 azure 表中添加我的自定义属性。

根据范围删除实体的任何想法?

4

1 回答 1

2

根据范围删除实体的任何想法?

在 Azure Tables 中执行批量删除,您需要使用Entity Group Transaction和添加要批量删除的实体,然后执行该批量操作。对于要批量操作(创建、更新或删除)的实体:

  • 它们应该具有相同的PartitionKey值。
  • 一个批次中最多可以包含 100 个实体。
  • 批处理的最大有效负载大小可以是 4MB。

请注意,即使一个实体在组事务中失败,整个事务也会回滚。

您可以在此处了解有关实体批量事务的更多信息:https ://docs.microsoft.com/en-us/rest/api/storageservices/performing-entity-group-transactions 。

于 2018-08-13T14:05:49.753 回答