加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc – 从基本控制器继承LINQ-to-SQL数据上下文

发布时间:2020-12-15 19:57:12 所属栏目:asp.Net 来源:网络整理
导读:我的基本控制器类BaseController由面向公众的控制器继承,以访问具有LINQ-to-SQL的请求之间的共享数据上下文. 我是否以高效安全的方式访问我的数据上下文,将其存储在每个HTTP请求的HttpContext.Current.Items中? DataContextHelper类 internal static class
我的基本控制器类BaseController由面向公众的控制器继承,以访问具有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的常见模式.

我执行每个控制器操作后唯一要添加显式处理的东西.只是为了确保一切都正确处理.

在BaseController.cs中:

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

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

        context.Dispose();
    }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读