当在视图中编辑记录时,数据库表中的字段无效
问题描述:
每当我尝试编辑我在ASP.NET MVC项目中创建的记录时,当我单击“保存”时,字段都是无效的。当在视图中编辑记录时,数据库表中的字段无效
这里是我的控制器,我的编辑得到了部分代码和岗位:
查看控制器:
// GET: Reviews/Edit/5
public ActionResult Edit(int? id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
Review review = db.Reviews.Find(id);
if (review == null)
{
return HttpNotFound();
}
ViewBag.ReviewID = new SelectList(db.Reviews, "ReviewID", "Rating", review.ReviewID);
return View(review);
}
// POST: Reviews/Edit/5
// To protect from overposting attacks, please enable the specific properties you want to bind to, for
// more details see http://go.microsoft.com/fwlink/?LinkId=317598.
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Edit([Bind(Include = "ReviewID,Username,WellnessService,Rating,Feedback,Date")] Review review)
{
if (ModelState.IsValid)
{
db.Entry(review).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("ReviewEdit");
}
ViewBag.ReviewID = new SelectList(db.Reviews, "ReviewID", "Rating", review.ReviewID);
return View(review);
}
这里是我的观点叫做编辑代码:
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<h4>@Html.DisplayFor(model => model.WellnessService)</h4>
<hr />
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
@Html.HiddenFor(model => model.ReviewID)
<div class="form-group">
@Html.LabelFor(model => model.Rating, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10" align="left">
@{
List<SelectListItem> listItems = new List<SelectListItem>();
listItems.Add(new SelectListItem { Text = "1", Value = "1" });
listItems.Add(new SelectListItem { Text = "2", Value = "2" });
listItems.Add(new SelectListItem { Text = "3", Value = "3" });
listItems.Add(new SelectListItem { Text = "4", Value = "4" });
listItems.Add(new SelectListItem { Text = "5", Value = "5" });
listItems.Add(new SelectListItem { Text = "6", Value = "6" });
listItems.Add(new SelectListItem { Text = "7", Value = "7" });
}
@Html.DropDownListFor(model => model.Rating, listItems, "Please choose value")
@Html.ValidationMessageFor(model => model.Rating, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Feedback, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.TextAreaFor(model => model.Feedback, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Feedback, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Save" class="btn btn-default" />
</div>
</div>
</div>
}
<div>
@Html.ActionLink("Back to My Reviews", "ReviewEdit", new { @class = "btn btn-success btn-lg" })
</div>
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
帮助将不胜感激
在此先感谢
答
没有一个dev电脑来检查这个,但你确定审查中有数据。如果有,你能确定下面的行可以工作吗?
db.Entry(review).State = EntityState.Modified;
您是否需要将评论附加到上下文中?
如果你暂时做某件事会发生什么;
if (ModelState.IsValid)
{
var foo = db.Entry.Where(x=>x.reviewId == review.reviewId).First();
// then manually set all the parameters
db.SaveChanges();
return RedirectToAction("ReviewEdit");
}
它不是优雅,但其是否正常工作,你的数据被更新,至少你知道它要连接的对象上下文的方式。 稍后我会尝试获取更好的示例,以便能够访问开发工作站。
您可以在控制器方法后的Edit()中放置一个断点,并查看“review”的内容是什么?它也是空吗? –