在MVC应用程序中设置的DB上下文可用多长时间?

时间:2013-02-26 09:12:52

标签: asp.net asp.net-mvc asp.net-mvc-3

我的MVC应用程序中有以下内容:

namespace WebUx.Areas.User.Controllers
{
    [Authorize]
    [InitializeSimpleMembership]
    public class AccountController : Controller
    {

加:

[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
public sealed class InitializeSimpleMembershipAttribute : ActionFilterAttribute
{
    private static SimpleMembershipInitializer _initializer;
    private static object _initializerLock = new object();
    private static bool _isInitialized;

    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        // Ensure ASP.NET Simple Membership is initialized only once per app start
        LazyInitializer.EnsureInitialized(ref _initializer, ref _isInitialized, ref _initializerLock);
    }

    private class SimpleMembershipInitializer
    {
        public SimpleMembershipInitializer()
        {
            System.Diagnostics.Debug.Write("Set Initializer\n");
            Database.SetInitializer<UsersContext>(null);


            try
            {
                using (var context = new UsersContext())
                {
                    if (!context.Database.Exists())
                    {
                        // Create the SimpleMembership database without Entity Framework migration schema
                        ((IObjectContextAdapter)context).ObjectContext.CreateDatabase();
                    }
                }

                WebSecurity.InitializeDatabaseConnection("DefaultConnection", "UserProfile", "UserId", "UserName", autoCreateTables: true);

            }

据我所知,当调用帐户控制器时,这将设置数据库上下文,但一旦设置完毕,它将保持为我的应用程序设置。以后为其他连接用户怎么办? DB上下文是否始终可用?

我问这个的原因是我有其他信息要存储在表中并使用Web API进行访问。我应该为这些控制器编写类似的代码,以便每次检查是否有可用的DB上下文,或者我可以使用它吗?

1 个答案:

答案 0 :(得分:1)

连接紧密耦合到DbContext。因此,只有在您的案例中继承DbContextUsersContext的类保留其范围时,才会打开该连接。

在您的示例中,UsersContext的范围限定为using块。

using (var context = new UsersContext())
{
 //some actions
}

因此,一旦“某些操作”完成,连接将关闭,任何访问延迟加载的尝试都将抛出异常,说明连接不再可用。每次需要访问数据库时,我都应该在我看来开始新的连接。您要确保的是,您只能实际访问数据库。确保您的查询已经过优化,这样您就不会多次访问数据库而不是一次性完成所有操作,因为这会影响您的性能。

修改

作为旁注,使用块分解为:

try{
 var context = new UsersContext();
 //some actions
}finally{
 context.Dispose();
}