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

相关内容

热门资讯

重大通报!大菠萝辅助挂开挂,广... 重大通报!大菠萝辅助挂开挂,广东雀神智能插件官网,玩家教你(有挂分享);亲,有的,ai轻松简单,又可...
重大通报!天酷大厅辅助,新蛮王... 重大通报!天酷大厅辅助,新蛮王辅助器,安装教程(有挂细节);相信小伙伴都知道这个新蛮王辅助器上存在很...
今日焦点!微乐山西脚本插件,新... 今日焦点!微乐山西脚本插件,新上游通用卦,靠谱教程(新版有挂);小薇(透视辅助)致您一封信;亲爱微乐...
科技揭秘!枫叶辅助官网,新九游... 科技揭秘!枫叶辅助官网,新九游辅助器软件激活码,安装教程(真的有挂);暗藏猫腻!新九游辅助器软件激活...
记者揭秘!微信小程序自动透视微... 记者揭秘!微信小程序自动透视微乐,上品游戏辅助器,实用技巧(有挂分析)相信很多朋友都在电脑上玩过微信...
一分钟揭秘!卡农免费辅助,樱花... 一分钟揭秘!卡农免费辅助,樱花之盛低价挂,第三方教程(有挂秘籍);樱花之盛低价挂最新版本免费下载安装...
推荐攻略!乐逍遥脚本辅助,神兽... 推荐攻略!乐逍遥脚本辅助,神兽互娱辅助免费,必备教程(有挂教程);神兽互娱辅助免费免费下载原版,在神...
必备教程!火神大厅辅助,新道游... 您好:新道游正版作弊这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特...
玩家必备攻略!随意玩有辅助,吉... 您好:吉祥填大坑辅助器攻略这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户...
科普!潘茄辅助,新二号辅助软件... 科普!潘茄辅助,新二号辅助软件下载,德州论坛(揭秘有挂);新二号辅助软件下载简单的灵活控制,仅凭一根...