我正在使用.NET Core和EF Core进行Web项目。我正在努力寻找如何查询多对多的关系。这就是我的模型:
public class Begrip
{
public int ID { get; set; }
public string Name { get; set; }
public string Desc { get; set; }
[Url]
public string URL { get; set; }
public ICollection<BegripCategory> Categories { get; set; }
}
public class Category
{
public int ID { get; set; }
public string Name { get; set; }
public ICollection<BegripCategory> Begrippen { get; set; }
}
public class BegripCategory
{
public int begripId { get; set; }
public Begrip begrip { get; set; }
public int categoryId { get; set; }
public Category category { get; set; }
}
和我的数据库上下文:
public class PBBContext : DbContext
{
public PBBContext (DbContextOptions<PBBContext> options)
: base(options)
{
}
public DbSet<PBB.Models.Movie> Movie { get; set; }
public DbSet<PBB.Models.Begrip> Begrip { get; set; }
public DbSet<PBB.Models.Category> Category { get; set; }
public DbSet<PBB.Models.BegripCategory> BegripCategory { get; set; }
protected override void OnModelCreating(ModelBuilder modelbuilder)
{
modelbuilder.Entity<BegripCategory>().HasKey(bc => new { bc.begripId, bc.categoryId });
modelbuilder.Entity<BegripCategory>().HasOne(b => b.begrip).WithMany(bg => bg.Categories).HasForeignKey(bc => bc.begripId);
modelbuilder.Entity<BegripCategory>().HasOne(c => c.category).WithMany(ca => ca.Begrippen).HasForeignKey(cc => cc.categoryId);
}
}
我试图做的是返回所有相应“类别”的JSON结果中的所有“Begrippen”,但是,我无法弄清楚如何获取它们的“类别”列表。
有任何想法吗?提前致谢。
EF Core不会自动加载相关属性,因此您需要明确地执行此操作,但以下内容应该可以解决这个问题:
var result = context.Begrip
.Include(x => x.Categories)
.ThenInclude(x => x.category);
请注意,intellisense并不总是可以工作。 .ThenInclude
包含,但代码仍应编译,即使它有红色下划线。
如果您将其返回到视图或API,您可能希望将其映射到DTO,这样您就不必处理.Categories[0].category.Name
等。
如果您需要过滤下面描述的多对多关系,我建议使用LinQ Enumerable Any方法,如下所示:
return result.Where(x => x.Categories.Any(c => c.category == categoryId));
返回由特定类别关联的已过滤实体列表。