加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 只有在属性的当前值为null时才能设置EntityKey属性

发布时间:2020-12-15 04:03:20 所属栏目:百科 来源:网络整理
导读:我试图以下列方式执行EF更新,但继续收到此错误: 只有当属性的当前值为null时,才能设置EntityKey属性. using (hydraEntities db = new hydraEntities()) { YouUser = db.youusers.Include("address").Include("entity").Include("youusercontacts.contact").
我试图以下列方式执行EF更新,但继续收到此错误:

只有当属性的当前值为null时,才能设置EntityKey属性.

using (hydraEntities db = new hydraEntities())
        {
            YouUser = db.youusers.Include("address").Include("entity").Include("youusercontacts.contact").Include("youuserlogins").Include("youusernotes.note").Include("youusernotes.youuser.entity").Where( yu => yu.YOUUserId.Equals(YOUUserId)).First();
        }

            YouUser.entity.FirstName = txtFirstName.Text;
            YouUser.entity.LastName = txtLastName.Text;
            YouUser.address.AddressLine1 = txtAddressLine1.Text;
            YouUser.address.AddressLine2 = txtAddressLine2.Text;
            YouUser.address.City = txtCity.Text;
            YouUser.address.State = ddlState.SelectedValue;
            YouUser.address.Zipcode = txtZipcode.Text;

            using (hydraEntities db = new hydraEntities())
            {
                db.youusers.AddObject(YouUser);
                db.ObjectStateManager.ChangeObjectState(YouUser,System.Data.EntityState.Modified);
                db.SaveChanges();
            }

非常感谢我如何解决这个问题并执行上述声明.

解决方法

在此方案中不要使用AddObject.它用于插入新实体,但您正在更新现有实体.改为使用Attach:
using (hydraEntities db = new hydraEntities())
{
    db.youusers.Attach(YouUser);
    db.ObjectStateManager.ChangeObjectState(YouUser,System.Data.EntityState.Modified);
    db.SaveChanges();
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读