首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在C#中防止重复的主键?

如何在C#中防止重复的主键?
EN

Stack Overflow用户
提问于 2017-05-06 21:00:49
回答 2查看 511关注 0票数 0

我尝试保存表单记录,并从客户端获取实体,但每次都获取PersonalId = 0,这将是重复的主键错误。

我怎么才能修复它呢?

代码语言:javascript
复制
public ActionResult SavePersonal(PersonalViewModel model)
{
    try 
    {
        StorageSystemEntities1 db = new StorageSystemEntities1();

        Personal personal = new Personal();
        personal.PName = model.PName;
        personal.PLastname = model.PLastname;
        personal.PStatus = model.PStatus;
        personal.ShopId = model.ShopId;
        personal.PPassword = model.PPassword;
        personal.GenderID = model.GenderID;
        personal.DOB = model.DOB;
        personal.Email = model.Email;
        personal.JobStartDate = model.JobStartDate;
        personal.PAuthorisation = model.PAuthorisation;
        personal.Phone = model.Phone;

        db.Personal.Add(personal);
        db.SaveChanges();

        int latestPersonalId = personal.PersonalID;
    }
    catch (Exception ex)
    {
        throw ex;
    }

    return RedirectToAction("_AddPersonal");
}
EN

回答 2

Stack Overflow用户

发布于 2017-05-06 21:12:15

有几种方法可以通过,例如:

  • 在你的应用程序中生成唯一的id (即guid)
  • 同样的事情,但是在你的数据库引擎(即sql过程)中
  • 使用sql标识正如上一个答案所提到的,因此在你的应用程序中不应该做任何事情
  • 希望上面的其中一个方法能帮助

<代码>F29

票数 0
EN

Stack Overflow用户

发布于 2017-05-06 21:37:13

Personal类中使用[DatabaseGenerated(DatabaseGeneratedOption.Identity)]

示例:

代码语言:javascript
复制
public class Personal {
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int PersonalId {get;set;}
    public string PName {get;set;}
    public string PLastname {get;set;}
    public string PStatus {get;set;}
    public int ShopId {get;set;}
    [DataType(DataType.Password)]
    public string PPassword {get;set;}
    public string GenderID {get;set;}
    public DateTime? DOB  {get;set;}
    [EmailAddress]
    public string Email {get;set;}
    public DateTime? JobStartDate  {get;set;}
    public string PAuthorisation {get;set;}
    [DataType(DataType.PhoneNumber)]
    public string Phone {get;set;}
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43820771

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档