を使用してNHibernateで行うように、DBラウンドトリップなしでIDがわかっているすでに永続的なオブジェクトへの参照を取得することは可能ISession.Load(id)
ですか?
1 に答える
1
はい、オブジェクトがすでに読み込まれている場合は可能です。EF Future CTP5 の場合、インスタンスの新しいLocal
プロパティを使用できます。DbSet<T>
var entity = context.MySet.Local.SingleOrDefault(e => e.Id == id);
ObjectContext
状況が少し複雑な場合 - POCO を操作するときに取得するのが面倒なインスタンスが必要ですEntityKey
。
私のリポジトリコードの一部:
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;
}
}
インスタンスがロードされていない場合、DB にクエリを実行せずに参照を取得することはできません。ダミー オブジェクトの作成を使用できます。
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 に答える