C# 如何在与同一其他类型具有其他关系的类型中定义EF多对多关系

C# 如何在与同一其他类型具有其他关系的类型中定义EF多对多关系,c#,ef-code-first,entity-framework-6,entity-framework-migrations,C#,Ef Code First,Entity Framework 6,Entity Framework Migrations,这是一个相当简单的问题,有相当长的解释,所以请容忍我,如果这变得很长。(我真的要尽量把它控制在最低限度) 好的,这是我的“提取样本”,产生了同样的问题 public class TestContext : DbContext { public DbSet<TypeA> TypeAs { get; set; } public DbSet<TypeB> TypeBees { get; set; } } public class TypeA { [Ke

这是一个相当简单的问题,有相当长的解释,所以请容忍我,如果这变得很长。(我真的要尽量把它控制在最低限度)

好的,这是我的“提取样本”,产生了同样的问题

public class TestContext : DbContext
{
    public DbSet<TypeA> TypeAs { get; set; }
    public DbSet<TypeB> TypeBees { get; set; }
}

public class TypeA
{
    [Key]
    public int Id { get; set; }
    public int SpecialBId { get; set; }
    public virtual ICollection<TypeB> Bees { get; set; }

    public virtual TypeB SpecialB { get; set; }
}

public class TypeB
{
    [Key]
    public int Id { get; set; }

    public virtual ICollection<TypeA> Aaas { get; set; }
}
您需要添加WithMany():

modelBuilder.Entity();
modelBuilder.Entity().HasMany(i=>i.Aaas).WithMany();
    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Entity<TypeA>().HasMany<TypeB>(i => i.Bees);
        modelBuilder.Entity<TypeB>().HasMany<TypeA>(i => i.Aaas);
    }
public partial class Initial : DbMigration
{
    public override void Up()
    {
        CreateTable(
            "dbo.TypeAs",
            c => new
                {
                    Id = c.Int(nullable: false, identity: true),
                    SpecialBId = c.Int(nullable: false),
                })
            .PrimaryKey(t => t.Id)
            .ForeignKey("dbo.TypeBs", t => t.SpecialBId, cascadeDelete: true)
            .Index(t => t.SpecialBId);

        CreateTable(
            "dbo.TypeBs",
            c => new
                {
                    Id = c.Int(nullable: false, identity: true),
                    TypeA_Id = c.Int(),
                })
            .PrimaryKey(t => t.Id)
            .ForeignKey("dbo.TypeAs", t => t.TypeA_Id)
            .Index(t => t.TypeA_Id);

    }

    public override void Down()
    {
        DropForeignKey("dbo.TypeAs", "SpecialBId", "dbo.TypeBs");
        DropForeignKey("dbo.TypeBs", "TypeA_Id", "dbo.TypeAs");
        DropIndex("dbo.TypeBs", new[] { "TypeA_Id" });
        DropIndex("dbo.TypeAs", new[] { "SpecialBId" });
        DropTable("dbo.TypeBs");
        DropTable("dbo.TypeAs");
    }
}
modelBuilder.Entity<TypeA>().HasMany<TypeB>(i => i.Bees).WithMany();
modelBuilder.Entity<TypeB>().HasMany<TypeA>(i => i.Aaas).WithMany();