Sha*_*ean 136 entity-framework ef-code-first entity-framework-4.1
没有Detach(object entity)上DbContext.
我是否能够首先在EF代码上分离对象?
Sla*_*uma 227
这是一个选项:
dbContext.Entry(entity).State = EntityState.Detached;
Run Code Online (Sandbox Code Playgroud)
Lad*_*nka 145
如果你想分离现有的对象,请按照@Slauma的建议.如果要在不跟踪更改的情况下加载对象,请使用:
var data = context.MyEntities.AsNoTracking().Where(...).ToList();
Run Code Online (Sandbox Code Playgroud)
正如评论中所提到的,这不会完全脱离实体.它们仍然是附加的并且延迟加载有效,但实体不会被跟踪.例如,如果您只想加载实体以读取数据而不打算修改它们,则应使用此选项.
The*_*bio 14
前面的两个答案都提供了很好的说明,但是,这两个答案都可能使您的实体仍然加载到 EF 的上下文和/或其更改跟踪器中。
当您更改小型数据集时,这不是问题,但当更改大型数据集时,这将成为问题。EF 会增加内存和资源使用量,这反过来又会降低过程性能,因为它使用更多的数据/实体。
其他两种方法都是有效的,但是在这种情况下,Microsoft 建议清理更改跟踪器,而不是单独分离实体
清除数据更改循环(例如更改一块数据)上的更改跟踪器可以使您免遭此麻烦。
context.ChangeTracker.Clear();
Run Code Online (Sandbox Code Playgroud)
这将从上下文中卸载/分离所有实体及其相关的changeTracker引用,因此在您的context.SaveChanges().
| 归档时间: |
|
| 查看次数: |
85679 次 |
| 最近记录: |