执行以下代码时出现此错误:
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"
这个错误意味着什么,我该如何解决?
答案 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,则也可能意味着您有重复的条目(两个条目具有相同的行键)。如果您单独写入条目时成功但批量写入失败,则很有可能。