问题
在调用 DbSet 的 Attach() 方法时(与将 Entity 设置为 EntityState.Unchanged 状态等价)报告如下错误:
An entity object cannot be referenced by multiple instances of IEntityChangeTracker.
缘由
实体对象的 DbContext 还没关闭,此时不容许再 Attach 到另外一个 DbContext 上。
Attach 的实体对象,必须是脱离 DbContext 的管制。
解决方法
方法一:先关闭作查询的 DbContext,再 Attach 到作更新的 DbContext 中。
方法二:将只用于查询的 DbContext 中的 DbSet 对象继续调用 AsNoTracking() 方法,这样获取的实体就不会被追踪,而后再将查询出的实体添加到另外一个要执行 Command 操做的 DbContext 上下文中。这种方法在使用 EntityFramework 的进行读写分离的架构中用处比较大。
参考文章: