我有这个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对象上进行哪些其他调用/设置以避免此错误?
谢谢!
答案 0 :(得分:11)
您的错误与DbContext对象无关。您的问题是您正在尝试插入具有重复主键的记录。这就是你的异常消息所说的。
了解如何创建CompanyAddress对象以及保存它们时的键 - 这将为您提供线索。
编辑:将主键设为自然键是个坏主意,即您不应将城市和地址指定为主键。您应该将Guid或Integer作为主键,而不依赖于存储在DB中的信息。
为了强制实现唯一性,在保存到数据库之前,检查该记录是否存在,并根据唯一约束为数据库表添加唯一索引。