Azure表存储错误:“操作的意外响应代码:99”

时间:2013-08-11 10:20:16

标签: exception azure azure-table-storage

执行以下代码时出现此错误:

var insert = new TableBatchOperation();
foreach (var entity in entities)
{
    insert.Insert(entity);
}
cloudTable.ExecuteBatch(insert);  

实体集合包含512个元素。 Azure SDK通过StorageException:

"Unexpected response code for operation : 99" 

这个错误意味着什么,我该如何解决?

2 个答案:

答案 0 :(得分:18)

此无描述性错误意味着Azure批量操作(至少在这种情况下)最多需要100个元素。限制你的批次,你会很好。

我最终使用了这样的东西:

public void Insert(IEnumerable<T> entities)
{
    foreach (var chunk in entities.Chunk(100))
    {
        InsertMaxLimitElements(chunk);
    }
}

private void InsertMaxLimitElements(IEnumerable<T> chunk)
{
    var insert = new TableBatchOperation();

    foreach (var entity in chunk)
    {
        insert.Insert(entity);
    }
    cloudTable.ExecuteBatch(insert);
}

Chunk扩展方法是从此answer复制的:

public static IEnumerable<IEnumerable<T>> Chunk<T>(this IEnumerable<T> source, int chunksize)
{
    while (source.Any())
    {
        yield return source.Take(chunksize);
        source = source.Skip(chunksize);
    }
}

答案 1 :(得分:0)

如果批量大小<100,则也可能意味着您有重复的条目(两个条目具有相同的行键)。如果您单独写入条目时成功但批量写入失败,则很有可能。