1

我的 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);

            }

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

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

4

1 回答 1

1

该连接与DbContext. DbContext因此,只有在您的继承类(UsersContext在您的情况下)保留其范围时,连接才会打开。

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

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

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

编辑

作为旁注, using 块分解为:

try{
 var context = new UsersContext();
 //some actions
}finally{
 context.Dispose();
}
于 2013-02-26T09:28:31.123 回答