从基本控制器继承LINQ-to-SQL数据上下文

Pet*_*ron 5 datacontext asp.net-mvc httpcontext linq-to-sql

我的基本控制器类BaseController由面向公众的控制器继承,以访问具有LINQ-to-SQL的请求之间的共享数据上下文.

  • 我是否通过将其存储在HttpContext.Current.Items每个HTTP请求中以高效和安全的方式访问我的数据上下文?

DataContextHelper

internal static class DataContextHelper
{
    public static MyDataContext CurrentContext
    {
        get
        {
            if (HttpContext.Current.Items["MyDataContext"] == null)
            {
                MyDataContext context = new MyDataContext();
                HttpContext.Current.Items["MyDataContext"] = context;
            }
            return (MyDataContext)HttpContext.Current.Items["MyDataContext"];
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

BaseController 类:

public class BaseController : Controller
{
    protected MyDataContext db
    {
        get {
            return DataContextHelper.CurrentContext;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

HomeController 类:

[HandleError]
public class HomeController : BaseController // inherits db member
{
    public ActionResult SomeAction(string id)
    {
        User user = db.Users.First(u => u.UserId == id);
        // ... do stuff
        db.SubmitChanges();
    }
}
Run Code Online (Sandbox Code Playgroud)

Joh*_*ell 4

是的,这是所有具有 WebForms 和 MVC 的主要 ORM 的常见模式。

我唯一会在执行每个控制器操作后添加显式处置。只是为了确保所有东西都得到正确处理。

在BaseController.cs中:

    protected override void OnActionExecuted(ActionExecutedContext filterContext)
    {
        if (HttpContext.Current.Items["MyDataContext"] == null)
            return;

        var context = (MyDataContext)HttpContext.Current.Items["MyDataContext"];

        context.Dispose();
    }
Run Code Online (Sandbox Code Playgroud)