Mat*_*hew 10 .net c# fluent ef-code-first entity-framework-4.1
我试图首先使用代码和流畅的API来创建一个对象,该对象包含来自同一个表的两个不同的实体.换句话说,转移对象持有对两个不同坦克对象的引用 - 一个是源,另一个是目的地.
但是,当我使用下面的代码时,我得到一个Exception,声明"引用关系将导致不允许的循环引用".
modelBuilder.Entity<Transfer>()
.HasRequired<Tank>(t => t.Source)
.WithMany(t => t.OutboundTransfers);
modelBuilder.Entity<Transfer>()
.HasRequired<Tank>(t => t.Destination)
.WithMany(t => t.InboundTransfers);
Run Code Online (Sandbox Code Playgroud)
我最好的猜测是,它认为我将两把钥匙指向同一辆坦克?知道我怎么能做到这一点?
编辑:从实体框架代码优先添加.WillCascadeOnDelete(false)找到答案- 来自同一个表的两个外键
正如您所说,您应该能够添加.WillCascadeOnDelete(false)- /sf/answers/389151031/
modelBuilder.Entity<Transfer>()
.HasRequired<Tank>(t => t.Source)
.WithMany(t => t.OutboundTransfers)
.WillCascadeOnDelete(false);
modelBuilder.Entity<Transfer>()
.HasRequired<Tank>(t => t.Destination)
.WithMany(t => t.InboundTransfers)
.WillCascadeOnDelete(false);
Run Code Online (Sandbox Code Playgroud)
我刚刚添加了这个答案,以便它不再显示在未答复列表中,因为未答复的答案为零。标记为社区 wiki :)