[英]asp.net mvc scaffolding and GUID as the primary key
我有一个具有以下结构的表
GUID uniqueidentifier with default value newid(), and set as primary key
ID int
Description varchar(max)
我使用 Visual Studio 创建了一个实体 Model,并生成了用于编辑/删除等的视图(mvc 脚手架)
问题在于“编辑”,当我单击该链接时,会显示带有正确数据的适当表单,但“保存”按钮根本不起作用。 请注意,其他链接(删除、创建、详细信息)可以正常工作..
所以,当我点击“编辑”链接时,url 是
http://localhost:10871/admin/Edit/e7d0c5ee-7782-411f-920e-7b0d93c924e1
并且表单显示正确,但保存按钮不起作用,没有网络活动发生。 使用 uniqueidentifers 作为主键有什么特别之处吗?
谢谢
- -代码 - -
编辑.cshtml
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>Domain</legend>
@Html.HiddenFor(model => model.GUID)
@Html.HiddenFor(model => model.ID)
<div class="editor-label">
@Html.LabelFor(model => model.Description)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Description)
@Html.ValidationMessageFor(model => model.Description)
</div>
<p>
<input type="submit" value="Save" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
--AdminController.cs--
// GET: /Admin/Edit/5
public ActionResult Edit(Guid id)
{
Domain domain = db.Domains.Single(d => d.GUID == id);
return View(domain);
}
//
// POST: /Admin/Edit/5
[HttpPost]
public ActionResult Edit(Domain domain)
{
if (ModelState.IsValid)
{
db.Domains.Attach(domain);
db.ObjectStateManager.ChangeObjectState(domain, EntityState.Modified);
db.SaveChanges();
return RedirectToAction("Index");
}
return View(domain);
}
Edit2针对 ZippyV 的评论,我在 Edit.cshtml 中添加了以下代码
<div class="editor-label">
@Html.LabelFor(model => model.ID)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.ID)
@Html.ValidationMessageFor(model => model.ID)
</div>
令我惊讶(或无知) - 显示的是 GUID 而不是 ID
除此之外 - 当我在该字段中输入一个值(1,2 或任何整数)时,我仍然收到消息“字段 ID 必须是一个数字”。
问题在于您的视图 model 上有一个名为 ID 的属性:
public class Domain
{
public int ID { get; set; }
...
}
同时,您的Edit
controller 操作中有一个名为id
的路由参数:
public ActionResult Edit(Guid id)
{
...
}
现在发生了什么: Html 帮助程序(例如 TextBoxFor、HiddenFor、...)总是首先在 model state 中查找,并且在绑定时仅在查询字符串中查找值model。 这就是所有 Html 助手的工作方式,这是设计使然。
所以你有以下内容:
@Html.HiddenFor(model => model.ID)
ID不是来自 model 而是来自您的路线数据(这是您的操作参数中指定的 Guid)。 这就是为什么在视图 model 和具有相同名称的操作参数中使用属性是非常危险的。
一种可能的解决方法是将您的操作参数重命名为其他名称:
public ActionResult Edit(Guid domainId)
{
Domain domain = db.Domains.Single(d => d.GUID == domainId);
return View(domain);
}
当然,现在您的路线可能需要调整或使用查询字符串参数: controller/edit?domainId=d578b4b7-48ec-4846-8a49-2120c17b6441
来调用编辑操作。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.