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

asp.net-mvc – 实体框架数据库 – 第一个uniqueidentity结果没

发布时间:2020-12-16 06:40:07 所属栏目:asp.Net 来源:网络整理
导读:我无法为主键生成新的guid id.每次我尝试创建另一个用户时都会得到相同的错误,因为它不会生成新的guid id. Violation of PRIMARY KEY constraint ‘PK_User’. Cannot insert duplicate key in object ‘dbo.User’. The duplicate key value is (00000000-0
我无法为主键生成新的guid id.每次我尝试创建另一个用户时都会得到相同的错误,因为它不会生成新的guid id.

Violation of PRIMARY KEY constraint ‘PK_User’. Cannot insert duplicate
key in object ‘dbo.User’. The duplicate key value is
(00000000-0000-0000-0000-000000000000). The statement has been
terminated.

码:

public partial class User
{
    [Key]
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public System.Guid Id { get; set; }
    public string UserName { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string Email { get; set; }
}

我的UserController代码

[HttpGet]
public ActionResult Create() {
    return View();
}

[HttpPost]
public ActionResult Create(User user) {
        if (ModelState.IsValid) {
            db.Users.Add(user);
            db.SaveChanges();

            return RedirectToAction("Index");
        }

        return View(user);
}

如何自动生成新的guid?

解决方法

您的c#代码没有生成任何GUID,因为您正在指示它执行此操作.您的模型表示Id的值由数据库生成(DatabaseGenerated(DatabaseGeneratedOption.Identity)) 问题出在数据库中的表定义中.如果您使用SQL Server,使用SQL Server管理工作室,请检查表的定义并确保ID实际定义为“Identity”

(编辑:李大同)

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

    推荐文章
      热点阅读