无法定义这两个对象之间的关系

本文关键字:对象 两个 之间 关系 定义 | 更新日期: 2023-09-27 18:28:15

我想在Users中添加和编辑项目。我使用这个代码:

DataContext db = new DataContext();
private void Save()
{
    User user = (SelectedUser == null) ? new User() : db.User.Find(SelectedUser.UserName);
    user.FirstName = FirstName;
    user.CcRowIndex = CcRowIndex;
    user.Image = Image;
    user.LastName = LastName;
    user.OrganizationalPostId = OrganizationalPost;
    user.OrganizationalUnitId = OrganizationalUnit;
    user.Password = Password;
    user.Signature = Signature;
    user.SubsetUsers = SubsetUsersList;
    user.UserName = UserName;
    if (SelectedUser == null)
    {
        db.User.Add(user);
    }
    db.SaveChanges();
}

我添加项目,但当我编辑项目时,我会收到错误:

无法定义这两个对象之间的关系,因为它们附加到不同的ObjectContext对象。+保存更改数据上下文

无法定义这两个对象之间的关系

查看User类的定义会有所帮助,不过,我可以猜测一下。

假设:

  • SubsetUsersList属性是其他User实例的集合

SubsetUsersList是从DbContext的另一个实例中填充的。当您尝试在DbContext的新实例中使用这些实体时,EF会抱怨。

// SubsetUsersList populated by unknown DbContext instance
user.SubsetUsers = SubsetUsersList;
// db instance throws exception
db.SaveChanges();

另一种选择是在当前db实例中加载这些用户:

// Guessing at the definition of your User class
var subsetUserIds = SubsetUsersList.Select(u => u.UserId).ToArray();
user.SubsetUsers = db.User.Where(u => subsetUserIds.Contains(u.UserId).ToList();

这不是有效的,但应该有助于您理解这里的问题。