DbContext
上没有Detach(object entity)
。
我是否有能力首先在EF代码上分离对象?
发布于 2011-04-09 04:00:44
如果你想分离现有的对象,遵循@Slauma的建议。如果要加载对象而不跟踪更改,请使用:
var data = context.MyEntities.AsNoTracking().Where(...).ToList();
正如注释中提到的,这不会完全分离实体。它们仍然是附加的,并且延迟加载工作,但是实体不会被跟踪。例如,如果您只想加载entity以读取数据,而不打算修改它们,则应使用此方法。
发布于 2011-04-09 03:00:02
这是一个选项:
dbContext.Entry(entity).State = EntityState.Detached;
发布于 2021-12-14 02:08:54
前面的两个答案都提供了很好的说明,但是,这两个答案都可能会给您留下仍然加载到EF的上下文和/或其变更跟踪器中的实体。
当你改变小的数据集时,这不是一个问题,但当你改变大的数据集时,这将成为一个问题。EF会增加内存和资源的使用,这反过来会降低过程的性能,因为它使用了更多的数据/实体。
其他两种方法都是有效的,但在这种情况下,Microsoft recommends清理更改跟踪器,而不是单独分离实体
清除数据更改循环上的更改跟踪器(例如,更改一大块数据)可以使您避免这种麻烦。
context.ChangeTracker.Clear();
这将从上下文中卸载/分离所有实体及其相关的changeTracker引用,因此在context.SaveChanges()
之后要小心使用。
https://stackoverflow.com/questions/5599147
复制相似问题