请教一个EF表之间多对多关系插入的问题

qq_30578553 2017-04-24 09:07:02
我有四个表,表的关系如图


BLL.test1BLL t1b = new BLL.test1BLL();
BLL.table2BLL t2b = new BLL.table2BLL();
var t2=t2b.GetList(en => true, en => en.table4).FirstOrDefault();
int a = t2.table4.td;
models.test1 t1 = new models.test1();
t1.table2.Add(t2);
t1b.Add(t1);

运行代码的话会报
一个实体对象不能由多个 IEntityChangeTracker 实例引用的错误。
我网上查了以后知道是由于我引用了table2表的table4,
“添加的对象对其他复杂类型有引用关系”,所以会报错。
请问有什么办法可以保留引用的同时添加成功吗?
...全文
302 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_30578553 2017-04-27
  • 打赏
  • 举报
回复
最后在DAL层新增了一个唯一的数据上下文,新增一个静态类,新增几个方法使用这个数据上下文来查询修改增加数据。

        studyEntities db3 = SingleContext.db2;
qq_30578553 2017-04-24
  • 打赏
  • 举报
回复
试了几次,貌似不是引用的问题,是出在出现了多个dbcontext的问题,莫非要DAL层用单例模式吗?

62,244

社区成员

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

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

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

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