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

相关内容

热门资讯

实测必看"约战平台辅... 实测必看"约战平台辅助"开挂(透视)werplan怎么作弊(有挂总结);1、点击下载安装,插件透视分...
透视黑科技"天天填大... 透视黑科技"天天填大坑辅助器免费下载"开挂(透视)pokemmo手机版脚本(发现有挂);1、很好的天...
盘点几款"中至小程序... 盘点几款"中至小程序破檞"开挂(透视)wpk作弊最怕三个东西(有挂存在)相信很多朋友都在电脑上玩过吧...
终于懂了"poker... 终于懂了"pokermaster辅助器"开挂(透视)we poker免费辅助器(有挂方式);1、超多...
科普分享"微信三哥玩... 科普分享"微信三哥玩辅助器"开挂(透视)德州真人透视脚本(有挂方略);微信三哥玩辅助器简单的透视挂控...
一分钟揭秘"新西部微... 一分钟揭秘"新西部微信辅助"开挂(透视)wepoker代打辅助(有挂分享);是一项软件透视开挂的竞技...
一分钟了解"德州扑克... 一分钟了解"德州扑克游戏辅助"开挂(透视)wepoker可以免费玩吗(有挂头条);德州扑克游戏辅助是...
玩家必用"微乐麻将自... 玩家必用"微乐麻将自建房app"开挂(透视)hh poker辅助有用吗(有挂辅助);是一款益智类棋牌...
透视好友"新众乐辅助... 透视好友"新众乐辅助"开挂(透视)智星菠萝透视(有挂功能);免费下载原版,在软件透视开挂可以安装到哦...
透视挂"雀姬手机辅助... 透视挂"雀姬手机辅助脚本"开挂(透视)wepoker手机版辅助(果真有挂);1. ai辅助创建新账号...