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

相关内容

热门资讯

详细透视!hhpoker免费辅... 详细透视!hhpoker免费辅助器,hhpoker脚本下载,果然真的有辅助app(哔哩哔哩)1、游戏...
推荐透视!aapoker公共底... 推荐透视!aapoker公共底牌,aapoker脚本,竟然是有辅助神器(哔哩哔哩)1、起透看视 辅助...
详细透视!wpk刷入池率脚本,... 详细透视!wpk刷入池率脚本,wpk德州局透视,原来是真的有辅助方法(哔哩哔哩)1、玩家可以在德州局...
揭露透视!aapoker脚本怎... 揭露透视!aapoker脚本怎么用,aapoker怎么拿好牌,都是一直总是有辅助方法(哔哩哔哩)1、...
教你透视!hhpoker买挂,... 教你透视!hhpoker买挂,hhpkoer辅助器,本来真的有辅助app(哔哩哔哩)1、游戏颠覆性的...
辅助透视!hhpoker有没有... 辅助透视!hhpoker有没有作比弊挂,德扑HHpoker有挂吗,切实一直总是有辅助方法(哔哩哔哩)...
揭露透视!aapoker透视怎... 揭露透视!aapoker透视怎么用,aapoker公共底牌,确实一直都是有辅助工具(哔哩哔哩)1)有...
了解透视!wpk德州局透视,w... 了解透视!wpk德州局透视,wpk透视是真的假的,总是一直总是有辅助教程(哔哩哔哩)德州局透视能透视...
解迷透视!hhpoker是真的... 解迷透视!hhpoker是真的还是假的,hhpoker有没有辅助,其实是真的有辅助神器(哔哩哔哩)一...
了解透视!wpk辅助器,wpk... 了解透视!wpk辅助器,wpk俱乐部是真的吗,一直真的是有辅助插件(哔哩哔哩)1、下载好透视辅助下载...