我的基本 Controller 类BaseController由面向公众的 Controller 继承,以使用LINQ-to-SQL访问请求之间的共享数据上下文。

  • 我是否通过将每个HTTP请求的数据上下文存储在HttpContext.Current.Items中来以高效且安全的方式访问我的数据上下文?
  • 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"];
            }
        }
    }
    
    BaseController类:
    public class BaseController : Controller
    {
        protected MyDataContext db
        {
            get {
                return DataContextHelper.CurrentContext;
            }
        }
    }
    
    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();
        }
    }
    

    最佳答案

    是的,这是带有WebForms和MVC的所有主要ORM的通用模式。

    在执行每个 Controller 操作后,我唯一要添加一个显式处理。只是为了确保一切都正确处理。

    BaseController.cs中,:

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

    关于asp.net-mvc - 从基本 Controller 继承LINQ-to-SQL数据上下文,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2684551/

    10-12 21:56