从一个对象到同一实体类型的两个对象的多个关联

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)找到答案- 来自同一个表的两个外键

Joe*_*nez 1

正如您所说,您应该能够添加.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 :)