是否可以在没有 DB 往返的情况下获得对已知 ID 的已持久对象的引用,就像使用 NHibernate 所做的那样ISession.Load(id)
?
问问题
300 次
1 回答
1
是的,如果对象已加载,则可能。如果是 EF Future CTP5,您可以使用实例Local
的新属性:DbSet<T>
var entity = context.MySet.Local.SingleOrDefault(e => e.Id == id);
如果情况ObjectContext
有点复杂 - 您需要EntityKey
使用 POCO 时很麻烦的实例。
我的存储库代码的一部分:
public class Repository<TEntity> : IRepository<TEntity> where TEntity : class, IEntity
{
private readonly EntitySetBase _entitySet;
private readonly string _entitySetName;
protected BaseObjectContext Context { get; set; }
protected ObjectSet<TEntity> ObjectSet { get; set; }
public Repository(BaseObjectContext context)
{
if (context == null)
{
throw new ArgumentNullException("context");
}
Context = context;
ObjectSet = context.CreateObjectSet<TEntity>();
var container = Context.MetadataWorkspace
.GetEntityContainer(Context.DefaultContainerName, DataSpace.CSpace);
_entitySet = container.BaseEntitySets
.Single(es => es.ElementType.Name == typeof (TEntity).Name);
_entitySetName = Context.DefaultContainerName + "." + _entitySet.Name;
}
public virtual IQueryable<TEntity> GetQuery()
{
return ObjectSet;
}
public virtual TEntity GetById(long id)
{
TEntity entity = TryGetLocalEntity(id);
if (entity == null)
{
entity = GetQuery().SingleOrDefault(o => o.Id == id);
}
return entity;
}
private TEntity TryGetLocalEntity(long id)
{
if (_entitySet == null)
{
return null;
}
var key = new EntityKey(_entitySetName, "Id", id);
ObjectStateEntry entry;
if (Context.ObjectStateManager.TryGetObjectStateEntry(key, out entry))
{
return (TEntity) entry.Entity;
}
return null;
}
}
如果未加载实例,您根本无法在不查询数据库的情况下获得参考。您可以使用虚拟对象创建。
CTP5 示例:
var entity = new MyEntity { Id = id };
context.MySet.Attach(entity);
纯 EF4 示例:
var entity = new MyEntity { Id = id };
context.Attach(entity);
或具有代理创建的虚拟对象(CTP5 示例):
CTP5 示例:
var entity = context.MySet.Create();
enity.Id = id;
纯 EF4 示例:
var entity = context.CreateObject<MyEntity>();
entity.Id = id;
于 2011-02-03T09:10:33.610 回答