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不与第一次加载中的数据相同,所以要重新加载一次,也就是其他人说的:数据要来源于查询,不是数据本身。
原谅小弟的拙见...