开发者

context.detach - for garbage collection

开发者 https://www.devze.com 2023-01-06 17:01 出处:网络
My application uses one开发者_JAVA技巧 context instance which exists for the lifetime of the application.I use Entity Framework to read and write all data to the database.After I add objects, I want t

My application uses one开发者_JAVA技巧 context instance which exists for the lifetime of the application. I use Entity Framework to read and write all data to the database. After I add objects, I want them to be cleaned up by the garbage collector so that they don't persist in memory. I've tried the following:

    While context.BatchProgresses.Count > 0
        context.Detach(context.BatchProgresses.First())
    End While

but this is runs into an infinite loop. Shouldn't Context.Detach() remove items from Context.BatchProgresses?


As usual in such cases, if you don't want to re-query the database, but work with entities attached to the context, you can use the ObjectStateManager:

var attachedEntities = context.
                       ObjectStateManager.
                       GetObjectStateEntries(EntityState.Added | 
                                             EntityState.Deleted |
                                             EntityState.Modified | 
                                             EntityState.Unchanged).
                       Where(ent => ent.Entity is BatchProgress).
                       Select(ent => ent.Entity as BatchProgress).
                       ToList();

foreach (var attachedEntity in attachedEntities)
{
    context.ObjectStateManager.ChangeObjectState(attachedEntity, EntityState.Detached);
}

Setting the ObjectState to EntityState.Detached removes the entity from the collection. You can check by fetching attachedEntities again in the end - there will be none.


It is only idea, but possible callingn of BatchProgress.First() causes database reading. Ensure (by logger or SQL profiler) no SQL activity is performed due that call.

Also you may try following code (C#)

var list = context.BatchProgress.ToList();
foreach(var item in list)
    context.Detach(item);
0

精彩评论

暂无评论...
验证码 换一张
取 消