我已經開始學習Asp.net最後一個弱點(我沒有任何以前的.net經驗),但是我在更新數據庫記錄時遇到了一些麻煩。Entity FrameWork更新記錄7.新記錄更新
我只見過一個類似的問題(How to update record using Entity Framework 7?),但它沒有使用窗體或控制器,所以它沒有太大的幫助。
我有一個對象
namespace Daycare.Models
{
public class Question
{
public Question() {
}
public int id { get; set; }
public string title { get;set;}
public string question { get; set; }
public string answer { get; set; }
public DateTime date { get; set; }
}
}
控制器和自動生成的景色。
刪除並創建工作正常,但編輯方法只創建新的空對象。
public IActionResult Edit(int? id)
{
if (id == null)
{
return HttpNotFound();
}
Question question = _context.questions.Single(m => m.id == id);
if (question == null)
{
return HttpNotFound();
}
return View(question);
}
// POST: Questions/Edit/5
[HttpPost]
[ValidateAntiForgeryToken]
public IActionResult Edit(Question question)
{
if (ModelState.IsValid)
{
//stuff i've tried.
// _context.questions.Update(question);
_context.Update(question);
// _context.Entry(question).State = EntityState.Modified;
_context.SaveChanges();
return RedirectToAction("Index");
}
return View(question);
}
這是形式
<form asp-action="Edit">
<div class="form-horizontal">
<h4>Question</h4>
<hr />
<div asp-validation-summary="ValidationSummary.ModelOnly" class="text-danger"></div>
<input type="hidden" asp-for="id" />
<div class="form-group">
<label asp-for="question" class="col-md-2 control-label"></label>
<div class="col-md-10">
<input asp-for="question" class="form-control" />
<span asp-validation-for="question" class="text-danger" />
</div>
</div>
<div class="form-group">
<label asp-for="title" class="col-md-2 control-label"></label>
<div class="col-md-10">
<input asp-for="title" class="form-control" />
<span asp-validation-for="title" 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>
</form>
我將不勝感激任何幫助。
非常感謝提前。
'詢問Q = new Question(); int b = integer(question.id); int _a = 5007; q.id = _a; _context.questions.Attach(question); _context.Entry(question).State = EntityState.Modified; _context.SaveChangesAsync(); ' 這似乎是工作,但我得到一個錯誤時, _A = question.id – Greenmachine