我很困惑为什么会发生这种情况,因为我已经解决了这个问题。当这个问题第一次发生时,我没有@Html.HiddenFor(model => model.OrganizationID)
通过表单的 POST 操作。在我把它放进去之后——它工作得很好。
现在,它不再工作了。当我尝试删除某些内容时,会引发 DbUpdateConcurrencyException。我的编辑视图工作得很好。
我按照本教程创建了模型优先方法。
这些是我的控制器 OrganizationController 中的删除操作:
public ActionResult Delete(int id)
{
using (var db = new VAGTCEntities())
{
return View(db.Organizations.Find(id));
}
}
//
// POST: /Organization/Delete/5
[HttpPost]
public ActionResult Delete(int id, Organization organization)
{
try
{
// TODO: Add delete logic here
using (var db = new VAGTCEntities())
{
db.Entry(organization).State = System.Data.EntityState.Deleted;
db.SaveChanges();
}
return RedirectToAction("Index");
}
catch
{
return View();
}
}
这是我的删除视图:
@model VAGTC.Models.Organization
@{
ViewBag.Title = "Delete";
}
<h2>Delete</h2>
<h3>Are you sure you want to delete this?</h3>
<fieldset>
<legend>Organization</legend>
<div class="display-label">
@Html.DisplayNameFor(model => model.Name)
</div>
<div class="display-field">
@Html.DisplayFor(model => model.Name)
</div>
</fieldset>
@using (Html.BeginForm()) {
@Html.HiddenFor(model => model.OrganizationID)
<p>
<input type="submit" value="Delete" /> |
@Html.ActionLink("Back to List", "Index")
</p>
}
我对其进行了调试以查看是否正在传递 id 并且它确实正在传递给 POST 操作。我不确定从这里去哪里。正如我搜索的任何内容一样,只需添加HiddenFor
声明即可。