我希望我能对在禁用跟踪的情况下使用dbcontext
时的最佳做法有一些了解。将context.Configuration.ProxyCreationEnabled
设置为false有什么含义?
据我了解,这将有效地禁用对实体的跟踪,但是如果我随后需要在这种情况下SaveChanges
怎么办?我想我记得曾见过一种获取上下文以手动跟踪特定实体的方法,但是我无法找到有关此信息的更多信息。在禁用了代理创建的上下文上调用SaveChanges
会对性能产生什么影响?
我也对使用无跟踪查询有类似的担忧。使用SaveChanges
检索数据后是否可以AsNoTracking
?
答案 0 :(得分:0)
如果没有ProxyCreationEnabled,则EF不会在未显式“包含”它们的情况下急于为您的对象加载子实体,并且更改跟踪也将被禁用。
如果使用AsNoTracking,则必须在对象上下文上将实体状态设置为“已修改”,以便持久保存更改。您可以使用以下代码来做到这一点:
context.Entry(entity).State = EntityState.Modified;
还有另外两个SO问题,更深入您的问题。
What are the downsides to turning off ProxyCreationEnabled for CTP5 of EF code first
DbSet.Attach(entity) vs DbContext.Entry(entity).State = EntityState.Modified