关于:无法定义这两个对象之间的关系,因为它们附加到不同的 ObjectContext 对象。个人解决方案

 1 public class UserClazz
 2 {
 3   public  User User{get;set;}
 4   public IList<Product> ProductList{get;set;}    
 5 }
 6 
 7 public class User
 8 {
 9    public IList<Product> ProductList{get;set;}
10    public IList<UserClazz> UserClazzList{get;set;}
11 }
12 
13 public class Product
14 {
15    public UserClazz UserClazz{get;set;}
16    public  User User{get;set;}
17 }

这是互相关联的三个表。

在使用EF更新时出现“无法定义这两个对象之间的关系,因为它们附加到不同的 ObjectContext 对象。”及“ 一个实体对象不能由多个 IEntityChangeTracker 实例引用。

这两个异常。

更新的代码是:

public void Update(int id,int ucId)
{
    try
    {
        var product=ProductSer.QueryById(id);
        product.UserClazz=UserClazzSer.QueryById(ucId);
        var reuslt=ProductSer.EditProduct(product);
    }
    catch(Exception ex)
    {
        throw new Exception(ex.Message);
    }
}

public bool EditProduct(Product product)
{
    blogRep.Update(blog);
    blogRep.SaveChange();//在这出错
}

后来百度,GOOGLE了一天,终于理解了异常的真正原因,请原谅我的愚笨...

public void Update(int id,int ucId)
{
    try
    {
        var product=ProductSer.QueryById(id);
        product.UserClazz=UserClazzSer.QueryById(ucId);
     //添加这句 product.User
=UserSer.QueryById(product.User.Id); var reuslt=ProductSer.EditProduct(product); } catch(Exception ex) { throw new Exception(ex.Message); } }

 我的理解是,在获取product时候由于饥饿加载将product中的User也加载出来了,而在更新的时候,Context中的product.User不与第一次加载中的数据相同,所以要重新加载一次,也就是其他人说的:数据要来源于查询,不是数据本身。

原谅小弟的拙见...

原文地址:https://www.cnblogs.com/FlyStupidBird/p/6027499.html