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)
是的,这是所有具有 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)
| 归档时间: |
|
| 查看次数: |
1040 次 |
| 最近记录: |