AspNet CORE - EF Many To Many to over same table with Join table(AspNet CORE - EF 多对多关系通过联接表实现同一表格的重复)
创始人
2024-09-20 05:00:19
0

首先,我们需要创建一个实体类来表示Join table,该表将用于连接两个具有多对多关系的实体。

public class JoinTable
{
    public int Entity1Id { get; set; }
    public Entity1 Entity1 { get; set; }
    public int Entity2Id { get; set; }
    public Entity2 Entity2 { get; set; }
}

接下来,我们创建两个实体类Entity1和Entity2,它们将具有多对多关系。

public class Entity1
{
    public int Id { get; set; }
    public string Name { get; set; }
    public ICollection JoinTables { get; set; }
}

public class Entity2
{
    public int Id { get; set; }
    public string Name { get; set; }
    public ICollection JoinTables { get; set; }
}

现在,我们需要在DbContext类中配置实体类之间的多对多关系。

public class ApplicationDbContext : DbContext
{
    public DbSet Entity1s { get; set; }
    public DbSet Entity2s { get; set; }
    public DbSet JoinTables { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity()
            .HasKey(jt => new { jt.Entity1Id, jt.Entity2Id });

        modelBuilder.Entity()
            .HasOne(jt => jt.Entity1)
            .WithMany(e1 => e1.JoinTables)
            .HasForeignKey(jt => jt.Entity1Id);

        modelBuilder.Entity()
            .HasOne(jt => jt.Entity2)
            .WithMany(e2 => e2.JoinTables)
            .HasForeignKey(jt => jt.Entity2Id);
    }
}

现在,我们可以使用这些实体类和DbContext来执行多对多关系的操作,例如添加关联关系。

public class Program
{
    static void Main(string[] args)
    {
        using (var context = new ApplicationDbContext())
        {
            var entity1 = new Entity1 { Name = "Entity1" };
            var entity2 = new Entity2 { Name = "Entity2" };

            var joinTable = new JoinTable
            {
                Entity1 = entity1,
                Entity2 = entity2
            };

            context.Entity1s.Add(entity1);
            context.Entity2s.Add(entity2);
            context.JoinTables.Add(joinTable);

            context.SaveChanges();
        }
    }
}

以上示例演示了如何使用AspNet Core和Entity Framework Core实现具有Join table的多对多关系。

相关内容

热门资讯

透视美元局“约局吧app有挂吗... 透视美元局“约局吧app有挂吗”透视辅助机制(都是真的是有挂);一、约局吧app有挂吗AI软件牌型概...
透视教学!德扑圈透视,(德普)... 透视教学!德扑圈透视,(德普)一贯存在有挂,可靠技巧(有挂插件)1、起透看视 德扑圈透视透明视辅助2...
透视软件“大菠萝辅助器”透视辅... 透视软件“大菠萝辅助器”透视辅助挂(真是真的有挂);1、很好的工具软件,可以解锁游戏的大菠萝辅助器a...
透视神器!德普之星私人局辅助免... 透视神器!德普之星私人局辅助免费,(德扑之心)其实有挂,可靠教程(有挂规律)所有人都在同一条线上,像...
透视能赢!菠萝德普辅助器免费版... 透视能赢!菠萝德普辅助器免费版在哪里,约局吧德州真的有透视挂吗,第三方教程(有挂攻略)1、菠萝德普辅...
透视代打!德普之星私人局辅助器... 透视代打!德普之星私人局辅助器,(德普之星)原来是真的有挂,靠谱教程(有挂解密)1、下载好德普之星私...
透视好友房“来玩app破解”透... 透视好友房“来玩app破解”透视辅助下载(确实是有挂)1、完成来玩app破解透视辅助安装,帮助玩家取...
透视app!德普之星私人局辅助... 透视app!德普之星私人局辅助免费,(德扑之心)确实有挂,AA德州教程(有挂技巧);德普之星私人局辅...
透视ai!拱趴大菠萝有挂吗,德... 透视ai!拱趴大菠萝有挂吗,德州透视是真的吗,实用技巧(有挂技巧)一、德州透视是真的吗软件透明挂的定...
透视好牌!德普之星辅助软件,(... 透视好牌!德普之星辅助软件,(德扑之心)确实是真的有挂,安装教程(有挂细节);1、完成德普之星辅助软...