我将 Visual Studio 2013 与 Sql Server 2012 一起使用。我使用它 为我的项目生成视图。我有两张桌子:
- UTILISATEUR (ID_UTILISATEUR,CIN,NOM,PRENOM...,ID_ROLE):
ID_UTILISATEUR是主键,ID_ROLE是外键。 - 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>....
请帮忙 !