4

假设我有以下代码:

TEModule teModule = Context.TEModules.Where(module => module.EnumValue.Equals(text.ModuleName)).FirstOrDefault();
if (teModule == null)
{
     teModule = new TEModule();
     teModule.EnumValue = text.ModuleName;
     Context.TEModules.AddObject(teModule);
     //Context.SaveChanges();
     TEModule aux = Context.TEModules.Where(module => module.EnumValue.Equals(teModule.ModuleName)).FirstOrDefault();
}

我的问题是,如果我保留“ SaveChanges ”注释,那么在下一个查询中,辅助对象始终为空,因为 Context.TEModules 是空的,即使我调用“ AddObject ”方法也是如此。但是,如果我在 AddObject 之后调用 SaveChanges,那么在下一个查询中,辅助对象不为空。问题是我不想经常调用 SaveChanges,因为这不是我添加对象的唯一一段代码,如果我这样做,性能会下降。

所以问题是:如果以后我需要知道对象是否已经存在,我是否必须在每次调用 AddObject 之后调用 SaveChanges?

4

1 回答 1

5

linq-to-entities 查询的目的是执行并在数据库中执行,因此如果您没有保存实体,则其数据库表示不存在。

如果您需要查找本地存储的实体(尚未持久化),则必须ObjectStateManager改为查询。

var entity = Context.ObjectStateManager.GetObjectStateEntries(EntitiState.Added)
                                       .Where(e => !e.IsRelationship)
                                       .Select(e => e.Entity)
                                       .OfType<TEModule>()
                                       .FirstOrDefault(m => m.EnumValue.Equals(teModule.ModuleName));
于 2011-08-30T10:40:51.100 回答