0

我在尝试从 Windows Azure 表存储下的表中选择一行时遇到一个奇怪的错误。异常“已添加具有相同密钥的项目”。即使我没有插入任何东西,也会被抛出。导致问题的查询如下:

var ids = new HashSet<string>() { id };
var fields = new HashSet<string> {"@all"};
using (var db = new AzureDbFetcher())
{
     var result = db.GetPeople(ids, fields, null);
}

public Dictionary<string, Person> GetPeople(HashSet<String> ids, HashSet<String> fields,     CollectionOptions options)
{
    var result = new Dictionary<string, Person>();
    foreach (var id in ids)
    {
         var p = db.persons.Where(x => x.RowKey == id).SingleOrDefault();
         if (p == null)
         {
                continue;
         }
       // do something with result
    }
}

正如你所看到的,只有 1 个 id 并且错误被抛出在循环的顶部并且没有被修改。

但是,我使用 "" 作为该特定行的分区键。是什么赋予了?

4

1 回答 1

0

在执行此查询之前,您可能向 DataServiceContext 添加了一个具有相同行键(并且没有分区键)的对象。然后您从数据存储中检索冲突的对象,并且由于冲突而无法将其添加到上下文中。

上下文跟踪从表中检索到的所有对象。由于实体由它们的 partitionKey/rowKey 组合唯一标识,因此上下文(如表)不能包含重复的 partitionkey/rowkey 组合。

这种碰撞的可能原因是:

  • 检索实体,修改它,然后使用相同的上下文再次检索它。
  • 将实体添加到上下文中,然后检索具有相同键的实体。

在这两种情况下,遇到的上下文已经在跟踪一个不同的对象,但该对象确实具有相同的键。这不是上下文可以自行解决的问题,因此是例外。

希望这可以帮助。如果您能提供更多信息,那将很有帮助。

于 2009-08-22T12:06:19.330 回答