gpt4 book ai didi

c# - Entity Framework "An object with the same key already exists in the ObjectStateManager."- 我无法理解如何从这里开始做什么

转载 作者:行者123 更新时间:2023-11-30 15:07:46 25 4
gpt4 key购买 nike

我正在构建一个 MVC3 项目,首先使用 Razor 和 Entity Framework 代码。我有两个模型:

public class Translation
{
public int TranslationId { get; set; }
public string Pt { get; set; }
public string Es { get; set; }
public string En { get; set; }
}

public class Page
{
public int PageId { get; set; }
public Translation Title { get; set; }
public Translation Description { get; set; }

public int? ParentPageId { get; set; } // page can have a parent page
public Page ParentPage { get; set; }
}

我为 Page 模型创建了用于 CRUD 的 PagesController。然后我编辑了 Create 和 Edit View ,为 Translation 属性添加了输入:

<div class="editor-field">
@Html.EditorFor(model => model.Title.Pt)
@Html.ValidationMessageFor(model => model.Title.Pt)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Title.Es)
@Html.ValidationMessageFor(model => model.Title.Es)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Title.En)
@Html.ValidationMessageFor(model => model.Title.En)
</div>

<div class="editor-field">
@Html.EditorFor(model => model.Description.Pt)
@Html.ValidationMessageFor(model => model.Description.Pt)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Description.Es)
@Html.ValidationMessageFor(model => model.Description.Es)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Description.En)
@Html.ValidationMessageFor(model => model.Description.En)
</div>

它在 Create 上运行良好,将两行新行添加到 Translations 表(一行由 Title_TranslationId 引用,另一行由 Description_TranslationId 引用)和输入内容。但是在更新时,我在行中收到了提到的错误:

db.Entry(page).State = EntityState.Modified;

PagesController 与创建时一样,因此没有进行额外的附加操作。如果我在“编辑” View 中删除其中一个翻译输入,它不会引发错误,但无论如何也不会更新翻译。

PagesController 代码:

private AdminEntities db = new AdminEntities();
public ViewResult Index()
{
return View(db.Pages.ToList());
}
public ViewResult Details(int id)
{
Page page = db.Pages.Find(id);
return View(page);
}
public ActionResult Create()
{
ViewBag.ParentPageId = new SelectList(db.Pages, "ParentPageId", "Description");
return View();
}
[HttpPost]
public ActionResult Create(Page page)
{
if (ModelState.IsValid)
{
db.Pages.Add(page);
db.SaveChanges();
return RedirectToAction("Index");
}
ViewBag.ParentPageId = new SelectList(db.Pages, "ParentPageId", "Description", page.ParentPageId);
return View(page);
}
public ActionResult Edit(int id)
{
Page page = db.Pages.Find(id);
ViewBag.ParentPageId = new SelectList(db.Pages, "ParentPageId", "Description", page.ParentPageId);
return View(page);
}
[HttpPost]
public ActionResult Edit(Page page)
{
if (ModelState.IsValid)
{
db.Entry(page).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
ViewBag.ParentPageId = new SelectList(db.Pages, "ParentPageId", "Description", page.ParentPageId);
return View(page);
}
}

请注意,ViewBag.ParentPageId 提供了一个我没有包含在 View 代码中的页面列表,因为如果我删除了翻译内容,它就可以工作。

有什么想法吗?

编辑:也许 EF 处理起来太复杂了?也许我应该改变我的做法。

最佳答案

已解决

我犯了两个初学者的错误。

错误 #1:忘记在 View 中添加翻译属性 Id,因此它们可以在 POST 方法中绑定(bind):

@Html.HiddenFor(model => model.Title.TranslationId)
@Html.HiddenFor(model => model.Description.TranslationId)

错误 #2:翻译属性,因为它们是 Translation 类的实例,必须在更新前设置为已修改:

db.Entry(page.Title).State = EntityState.Modified;
db.Entry(page.Description).State = EntityState.Modified;

db.Entry(page).State = EntityState.Modified;
db.SaveChanges();

现在可以了。我浪费了几个小时,但至少我认为我学到了一些东西 :)

关于c# - Entity Framework "An object with the same key already exists in the ObjectStateManager."- 我无法理解如何从这里开始做什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6259792/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com