c# – 如何刷新DbContext
发布时间:2020-12-16 01:20:28 所属栏目:百科 来源:网络整理
导读:我想刷新我的DbContext的所有实体而不重新创建它,我尝试了以下内容,但没有一个是有意义的: var context = ((IObjectContextAdapter)myDbContext).ObjectContext;var refreshableObjects = (from entry in context.ObjectStateManager.GetObjectStateEntries
我想刷新我的DbContext的所有实体而不重新创建它,我尝试了以下内容,但没有一个是有意义的:
var context = ((IObjectContextAdapter)myDbContext).ObjectContext; var refreshableObjects = (from entry in context.ObjectStateManager.GetObjectStateEntries( EntityState.Added | EntityState.Deleted | EntityState.Modified | EntityState.Unchanged) where entry.EntityKey != null select entry.Entity); context.Refresh(RefreshMode.StoreWins,refreshableObjects); //....................................................................... foreach (var entry in this.Orm.ChangeTracker.Entries()) { entry.State = EntityState.Unchanged; } this.Orm.ChangeTracker.DetectChanges(); 并且唯一一个刷新我的DbContext: foreach (var i in this.Orm.ChangeTracker.Entries()) i.Reload(); 但它太慢了.你能帮我选择正确的方法吗? 解决方法
我刚刚发现应该评估Enumerable结果,因为Refresh方法将其作为对象获取并且不对其进行评估.
var context = ((IObjectContextAdapter)myDbContext).ObjectContext; var refreshableObjects = (from entry in context.ObjectStateManager.GetObjectStateEntries( EntityState.Added | EntityState.Deleted | EntityState.Modified | EntityState.Unchanged) where entry.EntityKey != null select entry.Entity).ToList(); context.Refresh(RefreshMode.StoreWins,refreshableObjects); 我更喜欢以下内容: var refreshableObjects = myDbContext.ChangeTracker.Entries().Select(c=>c.Entity).ToList(); context.Refresh(RefreshMode.StoreWins,refreshableObjects); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |