如何避免System.Data.Entity.Infrastructure.DbUpdateException

时间:2013-12-24 15:01:26

标签: c# entity-framework-5

我有这个DbContext对象,它由 -

组成
- Employee
- CompanyAddress  (PK: AddressFirstLine, City)
Note: one Employee can have many CompanyAddress

仅当在CompanyAddress表中不存在某个地址时,记录才会添加到CompanyAddress表中。
如果我有两个来自数据库的DBContext对象,请说Snapshot1,Snapshot2。 假设在拍摄这两个快照时,CompanyAddress表中没有记录。 当对Snapshot1进行更改并保存时 - 记录将写入CompanyAddress表 当对Snapshot2进行更改并使用

保存时
mydataContext.SaveChanges();
发生

异常:

System.Data.Entity.Infrastructure.DbUpdateException: An error occurred while updating the entries
System.Data.SqlClient.SqlException: Violation of PRIMARY KEY constraint 'PK_CompanyAddress'. Cannot insert duplicate key in object 'dbo.CompanyAddress'

似乎保存Snapshot1会使Snapshot2变脏,因为当它们保存回数据库时,两者都有相同的 CompanyAddress记录。

我可以在dbContext对象上进行哪些其他调用/设置以避免此错误?

谢谢!

1 个答案:

答案 0 :(得分:11)

您的错误与DbContext对象无关。您的问题是您正在尝试插入具有重复主键的记录。这就是你的异常消息所说的。

了解如何创建CompanyAddress对象以及保存它们时的键 - 这将为您提供线索。

编辑:将主键设为自然键是个坏主意,即您不应将城市和地址指定为主键。您应该将Guid或Integer作为主键,而不依赖于存储在DB中的信息。

为了强制实现唯一性,在保存到数据库之前,检查该记录是否存在,并根据唯一约束为数据库表添加唯一索引。