当在视图中编辑记录时,数据库表中的字段无效

问题描述:

每当我尝试编辑我在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") 
     } 

帮助将不胜感激

在此先感谢

+0

您可以在控制器方法后的Edit()中放置一个断点,并查看“review”的内容是什么?它也是空吗? –

没有一个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"); 
} 

它不是优雅,但其是否正常工作,你的数据被更新,至少你知道它要连接的对象上下文的方式。 稍后我会尝试获取更好的示例,以便能够访问开发工作站。