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

相关内容

热门资讯

有挂方式开挂!九游破解辅助插件... 有挂方式开挂!九游破解辅助插件官网,wepoker透视是真的吗(透视有挂开挂辅助平台);无需打开直接...
存在有挂辅助!同乡有辅助,欢乐... 存在有挂辅助!同乡有辅助,欢乐情怀辅助器(带你了解开挂辅助神器);无需打开直接搜索薇:1367043...
有挂教程辅助!潮汕老友麻将开挂... 有挂教程辅助!潮汕老友麻将开挂,玉兔追月有挂吗(实测交流开挂辅助工具)【无需打开直接搜索加薇1367...
有挂助手开挂!圣游辅助器,同城... 有挂助手开挂!圣游辅助器,同城游辅助工具(透视攻略开挂辅助神器);无需打开直接搜索微信(136704...
有挂存在辅助!凑一桌关春天怎么... 有挂存在辅助!凑一桌关春天怎么才能开挂,欢聚水鱼辅助视频(一分钟揭秘开挂辅助神器) 了解更多开挂安装...
新版有挂开挂!顺欣茶楼辅助视频... 新版有挂开挂!顺欣茶楼辅助视频,衢州都莱有没有挂(玩家必看教程开挂辅助插件);亲,顺欣茶楼辅助视频这...
有挂规律辅助!微新欢乐卡五星辅... 有挂规律辅助!微新欢乐卡五星辅助,祺友互娱脚本(透视数据开挂辅助软件);无需打开直接搜索打开薇:13...
确实有挂开挂!飞驰娱乐辅助软件... 确实有挂开挂!飞驰娱乐辅助软件,山西扣点点辅助工具免费(科普攻略开挂辅助平台)【无需打开直接搜索加薇...
有挂方式开挂!鸿狐辅助器,盛世... 您好:盛世辅助器这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好...
有挂神器开挂!花花生活圈脚本,... 有挂神器开挂!花花生活圈脚本,哈糖大菠萝提高胜率(推荐一款开挂辅助脚本)【无需打开直接搜索加薇136...