mvc+ef,更新数据时 报错 “attaching an entity of type xxx failed”

cod了个er 2014-10-09 10:51:31

public string Add_Edit(Article art, string[] menuIds, string articleTagses)
{
//....
if (art.ArticleId > 0)
{
dbContext.Entry(article).State = EntityState.Modified;
a = dbContext.SaveChanges();

UpdateArticleMenu_Tags(article.ArticleId,menuIds,articleTagses);
}
//....
}


public int UpdateArticleMenu_Tags(int articleId, string[] menuIds, string articleTagses)
{
var a = 0;
try
{
var article = GetTheArticleModel(articleId, false);

var iarticleTagsRepository = new ArticleTagRepository(dbContext);
var tags = iarticleTagsRepository.AddTagses(articleTagses);

foreach (var tag in tags)
{
dbContext.Entry(tag).State = EntityState.Modified;
article.ArticleTagses.Add(tag);
}



var menuRepository = new MenuRepository(dbContext);
var menus = menuRepository.GetTheMenus(menuIds, false);
foreach (var menuId in menuIds)
{
var id = int.Parse(menuId);
var menu = menuRepository.GetTheMenu(id, false);
dbContext.Entry(menu).State = EntityState.Modified;
article.Menus_.Add(menu);
}


dbContext.Entry(article).State = EntityState.Modified;


a = dbContext.SaveChanges();


}
catch (DbUpdateException e)
{

}
catch (DbEntityValidationException ex)
{


}
catch (Exception ex)
{


}
return a;
}
...全文
456 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
cod了个er 2014-10-09
  • 打赏
  • 举报
回复
引用 5 楼 a419816897 的回复:
更新顺序没错吧 .
var tags = iarticleTagsRepository.AddTagses(articleTagses); var menus = menuRepository.GetTheMenus(menuIds, false); 这两句一用就报错,是不是这两个Repository查询,不能这么查询
mc_dv 2014-10-09
  • 打赏
  • 举报
回复
更新顺序没错吧 .
cod了个er 2014-10-09
  • 打赏
  • 举报
回复
引用 1 楼 duanzi_peng 的回复:
是不是 更新了数据库中的表中的字段名称或者类型,么有映射到EF中
我是Code First 不存在这种情况
cod了个er 2014-10-09
  • 打赏
  • 举报
回复
引用 2 楼 a419816897 的回复:
http://www.cnblogs.com/scy251147/p/3688844.html
这个我也看过了,如果更新的是自身字段就没事,但更新了关联属性,如我的Menus和Tags就会报错
mc_dv 2014-10-09
  • 打赏
  • 举报
回复
http://www.cnblogs.com/scy251147/p/3688844.html
  • 打赏
  • 举报
回复
是不是 更新了数据库中的表中的字段名称或者类型,么有映射到EF中

62,244

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧