c# - SQLite 内存数据库急切加载实体

标签 c# .net entity-framework sqlite

我已经将我们的测试切换为使用 SQLite :memory: 数据库而不是数据库文件,以加快我们的测试速度。一切都进行得很顺利,除了一个警告:它会自动急切地加载实体上的导航属性。

如果我运行该项目并使用实际的数据库文件通过 Postman 对其进行访问,它不会急切地加载它们,并且仅在我指定使用 .Include() 时才加载导航属性.

在我切换到 SQLite 内存数据库进行测试之前,它没有这样做。

DbContext配置如下:

        Configuration.LazyLoadingEnabled = true;
        Configuration.ProxyCreationEnabled = false;
        Configuration.ValidateOnSaveEnabled = true;

有没有人遇到过这个问题?

最佳答案

这是一篇旧帖子,但我想我会为偶然发现此问题的任何人提供答案。

这里可能发生的只是您的 DbContext 将实体缓存在其 ChangeTracker 中。无论底层提供者如何,当您将实体插入数据库时​​, Entity Framework 都会跟踪该实体。如果您查询刚插入的实体, Entity Framework 会假定该实体不会更改,因此会从 ChangeTracker 返回该实体。如果您将查询更改为执行 _myDbContext.Set<SomeEntity>().AsNoTracking().ToList()那么您应该会发现它执行了一个查询并且只预取了您指定的相关实体。

关于c# - SQLite 内存数据库急切加载实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44549030/

相关文章:

c# - .NET 4.0 是否与 Windows XP SP2 或更低版本兼容?

c# - MemoryCache.Add 返回 true 但不将项目添加到缓存

c# - 在azure sdk 2.5 blob存储中写入应用程序日志文件

c# - GoogleOAuth2AuthenticationOptions google+ API 关闭

c# - Windows 服务应用程序问题

c# - 如何使用 SpecFlow 测试选择的 html 控件对象?

entity-framework - 在 EF4 Code first Collection 是不是懒加载?

c# - 不一致的 TitleBar 高度返回

c# - Entity Framework 将多个属性序列化到一列

c# - Linq to Entity Groupby 并连接列