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

相关内容

热门资讯

黑科技辅助(微扑克)代打是真的... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
透视规律(wPk)外挂第一视角... 透视规律(wPk)外挂第一视角(黑科技)透视辅助可测试是真的假的(其实是真的有挂)1、ai辅助优化,...
黑科技真的(wepOke)黑科... 黑科技真的(wepOke)黑科技ai(黑科技)显示有做弊(切实真的是有挂)1、不需要AI权限,帮助你...
黑科技透明挂(wEPoke)辅... 黑科技透明挂(wEPoke)辅助透(黑科技)辅助软件靠谱(好像真的有挂)1)辅助挂:进一步探索辅助透...
黑科技中牌率(wepok)辅助... 黑科技中牌率(wepok)辅助工具的使用教程(黑科技)辅助挂(原来是有挂)是一款可以让一直输的玩家,...
黑科技ai代打(wePoke)... 黑科技ai代打(wePoke)软件规律(黑科技)软件免费版(竟然是有挂);致您一封信;亲爱玩家:《透...
黑科技线上(wEpOke)有插... 黑科技线上(wEpOke)有插件吗(黑科技)有外挂软件(果然真的是有挂)1、构建自己的微扑克辅助插件...
透视了解(WPK)手机德州扑克... 透视了解(WPK)手机德州扑克窥牌器(黑科技)最新黑科技(切实真的有挂)(1)透视了解(WPK)手机...
黑科技辅助(微扑克)ai代打(... 黑科技辅助(微扑克)ai代打(辅助挂)ai分析器(确实是有挂)辅助器中分为三种模型:软件透明挂、辅助...
透视规律(wPK)ai辅助(黑... 透视规律(wPK)ai辅助(黑科技)辅助(好像存在有挂)是一款可以让一直输的玩家,快速成为一个“必胜...