3

我对以下内容的含义有些困惑:

它们之间有什么区别?

1) AsNoTracking- 表示没有脏污检查。(与将 EntityState 更改为Detached?)

2) context.Detach(order)- (与将 EntityState 更改为Detached?)

3)NoTracking急切加载也需要?

 creativeWorkshopEntities.Job.MergeOption = MergeOption.NoTracking;
    var q = from c in creativeWorkshopEntities.Job.Include("Files")
            where c.Id == jobId                    
            select c; 

我想做的就是分离实体

usingBL class.

从数据库中填充缓存后,我无法分离实体

因为我仍然在应用程序流中调用它的属性。我猜它会抛出运行时异常(objectContext is desposed

你觉得我的逻辑对吗?

public static Group GetMamData(string stamp, MaMDBEntities maMDBEntities)
{
    Group group = MamDataCacheManager.GetMamData(stamp);
    if (group == null)
    {
        //was not found in the cache
        //check for aveilable test with status 'start' - 1
        group = GetGroupsFromDb(stamp, maMDBEntities);

        if (group != null)
        {
            maMDBEntities.Entry(group).State = EntityState.Detached;
            MamDataCacheManager.InsertMamData(stamp, group);
        }
    }

    //option B: attache a new context
    if (maMDBEntities.Entry(group).State == EntityState.Detached)
    {
        maMDBEntities.Groups.Attach(group);
    }
    return group;
}
4

1 回答 1

1

ORM (EF) 的主要功能之一是更改跟踪:跟踪更改/删除/新实体,以便生成正确的 SQL。

但是更改跟踪不是免费的,它需要相当多的一些空间。因此,当您不需要它时,请AsNoTracking用作优化。

1) AsNoTracking - 表示不进行脏污检查。(与将 EntityState 更改为 Detached 相同?)

最终结果是相同的,但在不跟踪的情况下加载它比稍后关闭它更便宜。

2) context.Detach(order) - (与将 EntityState 更改为 Detached 相同?)

基本上,是的。但我认为打电话Detach()是正确的方式。

3) 急切加载是否也需要 NoTracking?

不,我不这么认为。

于 2013-02-06T12:10:14.643 回答