2

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

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对象。+ datacontext的savechange

4

1 回答 1

1

查看您的课程的定义会有所帮助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();

这效率不高,但应该可以帮助您理解这里的问题。

于 2013-08-20T09:02:29.270 回答