我已经将我们的测试切换为使用 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/