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的多对多关系。

相关内容

热门资讯

7次性理解!顺欣茶楼辅助器“关... 7次性理解!顺欣茶楼辅助器“关于开挂辅助技巧”1、许多玩家不知道顺欣茶楼辅助器辅助软件怎么退出观战2...
1次性领会!台州哈狗有辅助软件... 1次性领会!台州哈狗有辅助软件“总结开挂辅助教程”1、这是跨平台的台州哈狗有辅助软件黑科技,在线的操...
五次性熟悉!情怀宜春可以开挂“... 五次性熟悉!情怀宜春可以开挂“专业开挂辅助插件”1、下载好情怀宜春可以开挂辅助软件之后点击打开,先需...
第一次性领会!wepoker私... 第一次性领会!wepoker私人局辅助器“分享开挂辅助软件”1)wepoker私人局辅助器辅助挂:进...
8次性辅助!决战十水三余音“外... 8次性辅助!决战十水三余音“外挂开挂辅助app”1、决战十水三余音透视辅助简单,决战十水三余音软件透...
5次性晓得!爱来大菠萝挂“专业... 5次性晓得!爱来大菠萝挂“专业开挂辅助技巧”1、不需要AI权限,帮助你快速的进行爱来大菠萝挂计算辅助...
6次性领会!聚友联盟免费辅助器... 6次性领会!聚友联盟免费辅助器下载地址“详情开挂辅助教程”1、聚友联盟免费辅助器下载地址透视辅助简单...
第9次性俱乐部!小程序边锋辅助... 第9次性俱乐部!小程序边锋辅助“普及开挂辅助技巧”1)小程序边锋辅助辅助挂:进一步探索小程序边锋辅助...
三次性领会!顺欣茶楼辅助视频“... 三次性领会!顺欣茶楼辅助视频“解密开挂辅助插件”1、顺欣茶楼辅助视频ai机器人多个强度级别选择2、顺...
2次性神器!武汉约战辅助“关于... 2次性神器!武汉约战辅助“关于开挂辅助工具”1、金币登录送、破产送、升级送、活动送。详细领取联系了解...