将DbContext注入Repository类库

ajb*_*ven 8 entity-framework dependency-injection inversion-of-control unity-container asp.net-mvc-4

我的解决方案中的项目设置如下:

  • 应用程序数据
  • App.Models
  • App.Web

在App.Data中,我使用Entity Framework通过一堆存储库访问我的数据以抽象与它的交互.出于显而易见的原因,我希望我的App.Web仅引用App.Data项目,而不是Entity Framework.

我正在使用构造函数注入来为我的控制器提供对如下所示的Repository容器的引用:

public interface IDataRepository
{
    IUserRepository User { get; set; }
    IProductRepository Product { get; set; }

    // ...
}

public class DataRepository : IDataRepository
{
    private readonly AppContext _context;

    public DataRepository(AppContext context)
    {
        _context = context;
    }

    // ...
}
Run Code Online (Sandbox Code Playgroud)

DataRepository将有一个AppContext对象(继承自Entity Framework DbContext),所有子存储库将用于访问数据库.

最后我们来讨论我的问题:如何使用Constructor Injection DataRepository考虑它是一个代码库并且没有入口点?我无法AppContext在App.Web中引导,因为那时我必须从该项目引用实体框架.

或者我只是在做一些愚蠢的事情?

quj*_*jck 12

您可以定义一个RepositoryConnectionApp.Data作为Context的包装器,并且不需要引用EF App.Web.如果您使用的是IoC容器,则可以控制RepositoryConnection类的生命周期,以确保所有实例都Repository获得相同的Context.这是一个简化的例子......

public class RepositoryConnection
{
    private readonly AppContext _context;

    public RepositoryConnection()
    {
        _context = new AppContext();
    }

    public AppContext AppContext { get { return _context; } }
}

public class DataRepository : IDataRepository
{
    private readonly AppContext _context;

    public DataRepository(RepositoryConnection connection)
    {
        _context = connection.AppContext;
    }

// ...
}
Run Code Online (Sandbox Code Playgroud)

  • 所以在上面的例子中,`RepositoryConnection`应该是`IDisposable`而``Dispose`方法只是调用`_context.Dispose()`? (3认同)