- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在我的桌面应用程序中使用 EF6 + WPF 和 MVVM 设计模式。我还使用 Autofac 作为 DI 容器。
我阅读了很多关于 EF 上下文生命周期管理的文章,我决定只为单个 View 模型实例设置一个 EF 上下文实例。我发现了几篇关于该方法的有趣文章,因此我认为这是管理 EF 上下文的唯一好方法。我使用 Autofac 来管理 EF 生命周期,所以每次我创建新的 View 模型时,都只会创建一个新的 EF 上下文。
当然,我遇到了一个问题。我的大多数 EF 查询都运行良好,但以下查询始终返回旧(缓存)值。每次按下“执行”按钮时我都会调用此查询,因此每个 View / View 模型都有很多次执行
this.context.someTable.Where(arg => arg.value == "value").Single();
我知道我总是可以用下面的代码重新加载实体
this.context.Entry(entity).Reload();
但对我来说这不是一个好的解决方案。我还知道,如果我处理当前上下文并在下一次查询之前重新创建,我将始终收到当前值。但是这种方法与每个 View 模型一个上下文的方法相冲突。
我应该修复/更改什么以避免 EF 缓存问题并仍然具有良好的性能。
最佳答案
你不应该保留上下文
我建议您放弃单一的共享上下文。我最近为一个大型 WPF 应用程序做了这个。 EF 上下文被设计为一个工作单元,您应该使用它然后调用 .Dispose()
。如果您需要急切地读取关系属性,则应使用 .Include()
提示。您应该在 using
block 中构建您的上下文,这样您就知道在哪里丢失了范围,并确保上下文被释放。
您会发现 EF 的性能实际上会降低,因为它需要引用其内部缓存和状态。我发现如果使用共享上下文,批量数据插入模式会恶化。 EF 的性能不如 RDBMS。
正如您所体验的那样,您可以保留上下文并从缓存的实体中受益,但如果这变得很痛苦,那么由于您的系统的性质和用户的要求,您将不再真正从缓存中受益。您的支持 RDBMS 应该足够快。一旦以任何方式缓存(包括 EF 二级缓存和 ASP.NET 输出缓存),您立即需要计划如何使缓存的实体过期。这为您的编码人员增加了更多工作,并为您的系统提供了惊人的新失败方式。
例如,考虑 EF 的一个好处是关系属性的自动解析。您可以无缝地跨越数据图,直到您遇到缓存和陈旧的实体。在这种情况下,很难在检索此类实体之前使缓存过期。
但是如果你必须在更新时重新加载
如果您真的不想将架构更改为 Microsoft 推荐/预期的方式。我建议您跟踪所有打开的上下文(在构建时添加到静态集合,在处理时删除,使用终结器模式仔细检查,以及在处理时抑制终结器),并在保存管道中实现一些通用代码(有几种方法这样做)尝试在所有打开的上下文中重新加载实体。这是一种使 EF 实体缓存过期的主动方式。这可能会影响较大集合的性能,但您可以处理白名单或黑名单实体,而不是处理所有保存的实体。
就个人而言,我很高兴我做出了改变(重组为短期上下文),从长远来看,在代码可维护性和系统稳定性方面有巨大的好处。
关于c# - EF 返回旧值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28042161/
EF POCO 和 EF Code First 有什么区别? 如果我一开始只使用 POCO,我可以将 EF 与它们一起使用吗? 最佳答案 如果您首先使用 EF 代码,您将拥有 POCO 对象,并且数据
EF POCO 和 EF Code First 有什么区别? 如果我一开始只使用 POCO,我可以将 EF 与它们一起使用吗? 最佳答案 如果您首先使用 EF 代码,您将拥有 POCO 对象,并且数据
我有一个基于 .NET 4.8 和 EF 6.4.4 的项目。我们正在逐步迁移到 .Net Core,但在此过程中我可以创建一个 .NET Core 数据上下文类 EF Core 并将两者指向相同的实
我有以下 Entity Framework 5 代码第一类 public class Airplane { public int Id { get; set; } public int
我正在尝试使用 Entity Framework Core 对现有数据库进行逆向工程.我试着按照指示from Microsoft但我遇到了错误: Unable to find provider ass
当数据库不是由 EF 代码首先创建时,有没有办法检查 DbContext 是否与数据库匹配? 我正在寻找与 Database.CompatibleWithModel 类似的功能但没有元数据。 最佳答案
目前,我正在重构我的上下文方法的测试,以不再需要真正的数据库。我使用 Ef Core。 所以我通读了 Microsoft 文档如何测试上下文方法。我首先找到了 EF6 测试的文档,然后阅读了 EfCo
我正在使用 EF 6 Database.SqlQuery 语句来执行存储过程,并实现错误和事务处理,打开和关闭事务(处理多个记录,如果一个记录有错误,仅回滚此,并提交其他任何内容无错误完成)。 Lis
我首先使用 EF 数据库,因为我喜欢在 SQL Management Studio 中设计我的数据库,坦率地说,让 Visual Studio 直接从数据库创建所有实体非常容易,而无需执行任何代码。
我的项目中有几个迁移文件,由于我对上次迁移进行了手动修改,所以我不想使用“程序包管理器控制台”重新生成它。我只需要添加 1 列。所以在之前的迁移中手动添加了这个(我可以这样做,因为还没有人升级过)。
原文:https://bit.ly/2umidlb 作者:jon p smith 翻译:王亮 声明:我翻译技术文章不是逐句翻译的,而是根据我自己的理解来表述的。其中可能会去除一些本人实在不知道如何组
我们想开始一个新项目,我们决定从一开始就在一些表中使用 Columnstore 索引和聚簇索引,我们如何使用 Code First EF Core 3.1 做到这一点? 最佳答案 您应该将主键更改为非
我在 Entity Framework 6.0 上。这是一个开发问题,而不是生产问题。 我想我有一个相互矛盾的策略。 目前,我设置了 DropCreateDatabaseIfModelChanges
我在 VS 2012 RTM 上,使用 EF 5。我在做代码优先,但由于我只是在开发中,所以试图忽略代码迁移。为了避免它们,我有这一套 Database.SetInitializer(new Drop
我有复杂的审计字段类型 我的复杂类型: [ComplexType] public class AuditData { [Column("CreatorUserId")] public
我已经阅读了很多关于如何在关系中指定外键名称的帖子,没有遇到任何问题。不过,我想知道的是,有没有办法更改主键和关系的命名方式? 例如,您有一个以 UserId 作为主键的 User 表。 EF 代码第
我刚刚安装了新的Entity Framework 4.1 NuGet包,因此根据NuGet指令和this article of Scott Hanselman替换了EFCodeFirst包。 现在,想
我的应用程序基于 .NET 4.0 和 EF 4。我现在正在考虑升级到最新版本。 是否有任何可能对我的申请产生不利影响的重大变化或行为差异? 升级路径有多简单?升级到 EF 5 是否需要任何代码更改或
假设您必须使用 EF Code First 和 POCO 类开发支持多种语言的网站,您将如何对 POCO 类进行建模以支持这种情况? 通过多语言支持,我的意思不仅是拥有例如在一些资源文件中为您的 UI
我首先使用 EF 4.1 代码。鉴于以下类片段: public class Doctor { public virtual ICollection Hospitals { get; set;
我是一名优秀的程序员,十分优秀!