1

我将 Visual Studio 2013 与 Sql Server 2012 一起使用。我使用 为我的项目生成视图。我有两张桌子:

  1. UTILISATEUR (ID_UTILISATEUR,CIN,NOM,PRENOM...,ID_ROLE):
    ID_UTILISATEUR是主键,ID_ROLE是外键。
  2. ROLE(ID_ROLE,NOM_ROLE,DESCRIPTION_ROLE):ID_ROLE是主键。

代码生成过程完成后,我有这个:

  • 控制器/UtilisateurController.cs 。
  • 一个新文件夹(Views/Utilisateur):Create.cshtml、Delete.cshtml、Details.cshtml、Edit.cshtml 和 Index.cshtml。

我的问题是,当我访问 Create.cshtml 页面时,重新输入字段并单击Create,我收到错误消息:Cannot insert explicit value for identity column in table 'UTILISATEUR' when IDENTITY_INSERT is set to OFF.

它解释了我无法将值插入标识列,因为它设置为 ON。我不知道我应该在以下代码中更改什么来解决它。


我在 UtilisateurController.cs 中的 Create 方法:

public ActionResult Create()
    {
        ViewBag.ID_ROLE = new SelectList(db.ROLE, "ID_ROLE", "NOM_ROLE");
        return View();
    }

    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult Create([Bind(Include="ID_UTILISATEUR,CIN_UTILISATEUR,MATRICULE_UTILISATEUR,NOM_UTILISATEUR,PRENOM_UTILISATEUR,PASSWORD_UTILISATEUR,MAIL_UTILISATEUR,TELEPHONE_UTILISATEUR,ID_ROLE")] UTILISATEUR utilisateur)
    {
        if (ModelState.IsValid)
        {
            db.UTILISATEUR.Add(utilisateur);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        ViewBag.ID_ROLE = new SelectList(db.ROLE, "ID_ROLE", "NOM_ROLE", utilisateur.ID_ROLE);
        return View(utilisateur);
    }    

错误行是:db.SaveChanges();


我的 Views/Utilisateur/Create.cshtml 页面是:

....
 @Html.ValidationSummary(true)

    <div class="form-group">
        @Html.LabelFor(model => model.ID_UTILISATEUR, new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.EditorFor(model => model.ID_UTILISATEUR)
            @Html.ValidationMessageFor(model => model.ID_UTILISATEUR)
        </div>
    </div>

    <div class="form-group">
        <label for="inputCIN" class="control-label col-xs-2">CIN</label><div class="col-md-10">
            @Html.EditorFor(model => model.CIN_UTILISATEUR)
            @Html.ValidationMessageFor(model => model.CIN_UTILISATEUR)
        </div>
    </div>.....
 <div class="form-group">
        <div class="col-md-offset-2 col-md-10">
            <input type="submit" value="créer" class="btn btn-default" />
        </div>....

请帮忙 !

4

1 回答 1

0

您收到此错误的可能原因是您可能已经更改/更改PKEY 列或数据。要修复,请转到您的“.edmx”文件并右键单击表“UTILISATEUR”并选择“从数据库更新模型”。这应该有效。

于 2014-12-11T07:30:09.863 回答