标签:百度 query code catch 个人 list use 解决方案 pre
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了一天,终于理解了异常的真正原因,请原谅我的愚笨...
关于:无法定义这两个对象之间的关系,因为它们附加到不同的 ObjectContext 对象。个人解决方案
标签:百度 query code catch 个人 list use 解决方案 pre
原文地址:http://www.cnblogs.com/FlyStupidBird/p/6027499.html