鉴于 Post 的对象模型有很多 PostTranslation,我设置了两个对象:
public partial class Post{
public Post() {
PostTranslations = new HashSet<PostTranslation>();
}
public int Id { get; set; }
public string Name { get; set; }
public ICollection<PostTranslation> PostTranslations { get; set; }
}
public partial class PostTranslation {
public int Id { get; set; }
public string Title { get; set; }
public int PostId { get; set; }
public Post Post { get; set; }
}
在我的上下文类中,在 OnModelBuilding 中,我有以下内容:
modelBuilder.Entity<Post>(entity => {
entity.ToTable("Posts");
entity
.HasMany<PostTranslation>(x => x.PostTranslations)
.WithOne(g => g.Post)
.HasForeignKey(g=>g.PostId);
});
在我的存储库中,我调用以下内容:
db.Posts.Include(t=>t.PostTranslations).ToList();
但在检查生成的 SQL 时,PostTranslations 从未加入,并且 Post 对象上的哈希集始终为零。有翻译,它们在数据库中正确连接。如果我直接查询它们,我可以从数据上下文中获取 PostTranslations。但我似乎无法让 EFCore 使用简单的 .Include 语句急切加载它们。
我错过了什么?
编辑 生成的 SQL 是这样的:
SELECT [f].[Id], [f].[Name] FROM [common].[Posts] AS [f]
我预计会在那里看到 PostTranslations 的左连接,所以在我迭代 ToList() 中的变量之后,翻译就会在那里。并且在模型构建器中设置了“通用”模式:
modelBuilder.HasDefaultSchema("common");

qq_遁去的一_1
白板的微信
随时随地看视频慕课网APP
相关分类