ASP.NETCoreMVC和EntityFramework中如何配置多对多关系?
创始人
2024-09-18 01:00:09
0
  1. 创建模型实体类和数据表 首先,创建模型实体和数据表以存储关联数据。在这个例子中,我们将创建一个Student和一个Class实体类,并创建一个StudentClass联接表来存储多对多关系。

Class.cs:

public class Class
{
    public int ClassId { get; set; }
    public string ClassName { get; set; }

    public ICollection StudentClasses { get; set; }
}

Student.cs:

public class Student
{
    public int StudentId { get; set; }
    public string StudentName { get; set; }

    public ICollection StudentClasses { get; set; }
}

StudentClass.cs:

public class StudentClass 
{
    public int StudentId { get; set; }
    public Student Student { get; set; }

    public int ClassId { get; set; }
    public Class Class { get; set; }
}

  1. 配置多对多关系

然后,在DbContext中配置多对多关系。在这个例子中,我们将通过覆盖OnModelCreating方法来配置多对多关系。

public class SchoolContext : DbContext
{
    public SchoolContext(DbContextOptions options)
        : base(options)
    {
    }

    public DbSet Students { get; set; }
    public DbSet Classes { get; set; }
    public DbSet StudentClasses { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity()
            .HasKey(sc => new { sc.StudentId, sc.ClassId });

        modelBuilder.Entity()
            .HasOne(sc => sc.Student)
            .WithMany(s => s.StudentClasses)
            .HasForeignKey(sc => sc.StudentId);

        modelBuilder.Entity()
            .HasOne(sc => sc.Class)
            .WithMany(c => c.StudentClasses)
            .HasForeignKey(sc => sc.ClassId);
    }
}

在这个方法中,我们使用EntityTypeBuilder API来配置StudentClass实体类作为多对多关系的中间关联表。

  1. 使用EF Core查询多对多关系数据

在查询多对多关系数据时,可以使用Include方法来包含关联数据。

var students = _context.Students
    .Include(s => s.StudentClasses)
        .ThenInclude(sc => sc.Class)
    .ToList();

在这个例子中,我们使用Include和ThenInclude来加载Student和关联的Class实体对象。

相关内容

热门资讯

WePoKe外挂!德州aapo... WePoKe外挂!德州aapoker俱乐部,(aa扑克)从前真的有挂(详细辅助2025新版总结)关于...
透视真的(微扑克ai辅助工具)... 透视真的(微扑克ai辅助工具)pokerrrr2挂(详细辅助必胜教程)原生真的有挂1、不需要AI权限...
透视有挂(wEpoKe)透视辅... 透视有挂(wEpoKe)透视辅助挂(wepoke智能ai)本然是有挂(详细透视揭秘教程);原来确实真...
智星德州菠萝偷偷看牌功能!wp... 智星德州菠萝偷偷看牌功能!wpk微扑克辅助,(aapokER)总是有挂(详细辅助专业教程)1、不需要...
透视中牌率(wepokeai代... 透视中牌率(wepokeai代打的胜率)微扑克辅助测试(详细辅助黑科技教程)原本真的有挂,您好,we...
透视辅助(wePOKE)外挂透... 1、透视辅助(wePOKE)外挂透明挂辅助挂(wepoke有没有挂)原生有挂(详细透视必胜教程)2、...
德州之星外挂!约局吧是正规的吗... 德州之星外挂!约局吧是正规的吗,(德州机器人)原生是有挂(详细辅助AI教程)是一款可以让一直输的玩家...
透视最新(德州免费辅助神器ap... 1、透视最新(德州免费辅助神器app)wepokeai代打(详细辅助微扑克教程)竟然有挂;代表性(透...
透视模拟器(WepOke)外挂... 透视模拟器(WepOke)外挂透明挂辅助工具(wepok软件透明挂)都是有挂(详细透视专业教程);《...
aapoker有挂!poker... aapoker有挂!pokerworld下载,(wePOke)本来是有挂(详细辅助教你攻略)是一款可...