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

相关内容

热门资讯

插件辅助挂!掌酷天天开心辅助器... 插件辅助挂!掌酷天天开心辅助器!竟然是有开挂辅助技巧(有挂规律)-哔哩哔哩1、玩家可以在掌酷天天开心...
2026版教程!海豹3+1辅助... 您好,海豹3+1辅助器这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩...
出乎意料的是!wepoker辅... 出乎意料的是!wepoker辅助脚本!切实存在有开挂辅助技巧(竟然有挂)-哔哩哔哩1、超多福利:超高...
据文件显示!阿拉游戏免费辅助器... 据文件显示!阿拉游戏免费辅助器!切实真的有开挂辅助脚本(有挂分享)-哔哩哔哩小薇(辅助器软件下载)致...
目前来看!越乡游义乌辅助器免费... 目前来看!越乡游义乌辅助器免费!确实是有开挂辅助方法(有挂方针)-哔哩哔哩1、上手简单,内置详细流程...
今天上午!免费宝宝浙江游戏辅助... 今天上午!免费宝宝浙江游戏辅助!竟然确实有开挂辅助方法(有挂解惑)-哔哩哔哩1、每一步都需要思考,不...
此事备受玩家关注!赣南好友辅助... 此事备受玩家关注!赣南好友辅助!其实真的有开挂辅助插件(详细教程)-哔哩哔哩1、不需要AI权限,帮助...
总结辅助挂!小闲川南手游辅助器... 总结辅助挂!小闲川南手游辅助器!好像真的是有开挂辅助教程(有挂规律)-哔哩哔哩1、下载好小闲川南手游...
据权威媒体报道!决战平安京辅助... 您好,决战平安京辅助软件这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多...
据了解!方片十三张辅助器软件!... 据了解!方片十三张辅助器软件!切实真的是有开挂辅助挂(有挂细节)-哔哩哔哩1、任何方片十三张辅助器软...