• 关于:无法定义这两个对象之间的关系,因为它们附加到不同的 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不与第一次加载中的数据相同,所以要重新加载一次,也就是其他人说的:数据要来源于查询,不是数据本身。

    原谅小弟的拙见...

  • 相关阅读:
    iftop 安装流程
    Centos 6.5 Tengine 安装流程
    linux 查看系统进程前十
    Centos 6.5 mongodb 安装流程
    linux 磁盘查看方式
    Linux 磁盘分区及挂载
    linux 路由添加
    rsyslog 重启
    文件上传到Web服务器
    一些链接1
  • 原文地址:https://www.cnblogs.com/FlyStupidBird/p/6027499.html
Copyright © 2020-2023  润新知