小编Vol*_*nem的帖子

无需在EF中部署DataContext/ObjectContext?

Albahari在"c#4.0简介"中写道:

>尽管DataContext/ObjectContext实现了IDisposable,但您可以(通常)在不处置实例的情况下逃脱.处置强制上下文与dispose的连接 - 但这通常是不必要的,因为只要完成从查询中检索结果,L2S和EF就会自动关闭连接<<

这感觉不对,FxCop也会抱怨,如果你没有放弃IDisposable的东西.

我有以下存储库代码:

    public abstract class Repository<TEntity> : IRepository<TEntity> where TEntity : class
    { ...
        public void Add(TEntity entity)
    {
        using (var dbContext = this.UnityContainer.Resolve<DbContext>())
        {
            dbContext.Set<TEntity>().Add(entity);
            dbContext.SaveChanges();
        }
    }

    ...

    public virtual IEnumerable<TEntity> Find(Expression<Func<TEntity, bool>> expression)
    {
       using (var dbContext = this.UnityContainer.Resolve<DbContext>())
       {
           return dbContext.Set<TEntity>().Where(expression).ToList().AsEnumerable();
       }
    }
    ...
Run Code Online (Sandbox Code Playgroud)

注意:我没有返回IQueryable - 延迟加载不应该发挥作用.Resolve DbContext配置为PerResolveLifetimeManager.

这种方法是正确的还是我需要根据Albaharis描述重新考虑这个问题?

entity-framework idisposable repository repository-pattern

10
推荐指数
1
解决办法
6756
查看次数