猿问

EF Core:一对多不是急切加载

鉴于 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
浏览 147回答 1
1回答

白板的微信

事实证明,这是一个命名空间问题。这是一个重构的存储库,在它的顶部,有:using&nbsp;System.Data.Entity;使用该命名空间,正确编译了 .Include 语句,但 EFCore 没有获取关系。添加:using&nbsp;Microsoft.EntityFrameworkCore;突然,SQL 正在为急切的负载正确生成连接。
随时随地看视频慕课网APP
我要回答