如何在存储库中正确处理Linq到SQL DataContext?

时间:2010-03-01 17:12:25

标签: c# asp.net-mvc linq-to-sql repository datacontext

在Rob Conery风格的ASP.NET MVC应用程序中,您通常有一个存储库:

public class CustomerRepository
{
    DataContext dc = new DataContext();

    public IQueryable<Customer> AllCustomers()
    {
        return db.Customers;
    }

    public Customer GetCustomer(int customerID)
    {
        return db.Customers.FirstOrDefault(c => c.CustomerID = customerID);
    }
}

和控制器:

public class CustomerController: Controller
{
    CustomerRepository _repository;

    public ActionResult Index()
    {
        var data = _repository.AllCustomers();
        return view("Index", data);
    }

    public ActionResult Details(int id)
    {
        var data = _repository.GetCustomer(id);
        if (data !=null)
            return view("Details", data);
        else
            return view("NotFound");
    }
}

当通过路由引擎将请求路由到ASP.NET MVC核心引擎中的Controller工厂时,控制器将被实例化。然后它在控制器上执行适当的方法。

假设我想在DataContext中实现IDisposable,那么如何正确地Dispose DataContext,而不必为存储库中的每个方法重新实例化DataContext?

2 个答案:

答案 0 :(得分:4)

使存储库处于一次性状态,并在其Dispose方法中处理datacontext。

如果您想知道是谁处置了回购,Rob可能会使用一个IOC容器,它会将repo注入到控制器中,并且每个请求都有一个实例,并且会在请求结束时自动处理回购。

答案 1 :(得分:1)

实际上DataContextIDisposable。您应该在using(CustomerRepository _repository = new CustomerRepository()) { ... }中将每个操作都包装在控制器中,并通过调用IDisposable

在存储库中实现ds.Dispose()