我很难过 - 升级到Entity Framework 7,我通常会覆盖DbContext
的SaveChanges,以便能够在更改之前获取所有修改对象的列表。最终,我有一个可以跟踪数据库中先前版本的脚本。在Entity Framework 6中,我会得到模型更改,如下所示:
var oc = ((IObjectContextAdapter)this).ObjectContext;
var modifiedItems = oc.ObjectStateManager.GetObjectStateEntries(EntityState.Modified | EntityState.Deleted);
List<ObjectStateEntry> ModifiedObjlist = modifiedItems.ToList();
但是现在在Entity Framework 7中删除了ObjectContext
,我被困住了,我将如何在Entity Framework 7中获取修改对象的列表?
var modifiedEntries = context.ChangeTracker
.Entries()
.Where(x => x.State == EntityState.Modified)
.Select(x =>x.Entity)
.ToList();
@dotctor的代码在某些情况下可能不起作用。
在某些情况下,更改跟踪器可能不具有关于由上下文管理的实体的最新信息,因此可以修改/添加/删除实体而无需更改跟踪器知道。为了避免这种情况,我将@dotctor的代码包装在以下条件中:
if(context.ChangeTracker.HasChanges())
{
...
}
Microsoft的ChangeTracker.HasChanges()摘要 :
检查是否正在跟踪任何新的,已删除或已更改的实体,以便在调用DbContext.SaveChanges或DbContext.SaveChangesAsync时将这些更改发送到数据库。请注意,除非将ChangeTracker.AutoDetectChangesEnabled设置为false,否则此方法会调用ChangeTracker.DetectChanges。