如何在Entity Framework中更新数据库记录?

3
我正在使用c# mvc和EF构建网站。当我用新值更新表时,会出现以下错误。
{"违反主键约束条件'PK_Table_1_1'。无法在对象'dbo.User'中插入重复的关键字。重复的键值为(shan@gmail.com)。\r\n该语句已终止。"}
这是我的表设计。

enter image description here

这是我的控制器文件

[HttpPost]
    public ActionResult Manage(ManageViewModel manageviewmodel)
    {
        TheFoodyContext db = new TheFoodyContext();
        string UserEmail = Session["UserEmail"].ToString();
        User user_to_update = db.Users.Find(UserEmail);

        if (ModelState.IsValid)
        {

            try
            {
                HttpPostedFileBase photo = Request.Files["photo"];

            if (photo != null && photo.ContentLength > 0)
            {
                var path = "";
                var fileName = Path.GetFileName(photo.FileName);
                var extension = Path.GetExtension(photo.FileName);
                var allowedExtensions = new[] {".Jpg", ".png", ".jpg", "jpeg"};
                if (allowedExtensions.Contains(extension))
                {
                    string name = Path.GetFileNameWithoutExtension(fileName);
                    string myfile = name + "_" + UserEmail + extension;
                    path= Path.Combine(Server.MapPath("~/Img"), myfile);
                    photo.SaveAs(path);
                    user_to_update.photo = myfile;

                }
                else
                {
                    ViewBag.message = "Please choose only Image file";
                }


                user_to_update.email = UserEmail;
                user_to_update.fname = manageviewmodel.FirstName;
                user_to_update.lname = manageviewmodel.LastName;
                user_to_update.phone = manageviewmodel.Phone;
                user_to_update.address = manageviewmodel.Address;
                user_to_update.city = manageviewmodel.City;
                user_to_update.postcode = Convert.ToDecimal(manageviewmodel.PostCode);
                user_to_update.district = manageviewmodel.District;
                user_to_update.user_type = manageviewmodel.UserType;
                user_to_update.status = manageviewmodel.Status;
                user_to_update.photo = path;

                db.Users.Add(user_to_update);
                db.SaveChanges();

                Session["UserEmail"] = UserEmail;
                Session["FirstName"] = manageviewmodel.FirstName;
                Session["LastName"] = manageviewmodel.LastName;
                Session["Address"] = manageviewmodel.Address;
                Session["City"] = manageviewmodel.City;
                Session["PostCode"] = manageviewmodel.PostCode;
                Session["District"] = manageviewmodel.District;
                Session["UserType"] = manageviewmodel.UserType;
                Session["Status"] = manageviewmodel.Status;
                Session["Phone"] = manageviewmodel.Phone;
                return RedirectToAction("Manage");
            }
            }
            catch (Exception ex)
            {
             return View(ex.Message);
            }
            return View(manageviewmodel);
            }

            return View(manageviewmodel);

        }

这是我的模型文件

public class ManageViewModel
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string Email { get; set; }
    public string Phone { get; set; }
    public string photo { get; set; }
    public string Address { get; set; }
    public string City { get; set; }
    public int PostCode { get; set; }
    public string District { get; set; }
    public string UserType { get; set; }
    public string Status { get; set; }
}
1个回答

5
您不需要再添加用户(因为它已经存在且EF跟踪更改),只需调用SaveChanges即可完成操作。
只需删除此行即可:
db.Users.Add(user_to_update);

它应该可以正常工作(除非还有更多的错误)。


为什么要踩?你不能添加已经存在的实体。这将具有相同的键并解释了OP的异常。 - Marco
@Manfred Radlwimmer 非常感谢。它像魔法一样奏效了。 :) - Punya Munasinghe

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接