我的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上下文,或者我可以使用它吗?
答案 0 :(得分:1)
连接紧密耦合到DbContext
。因此,只有在您的案例中继承DbContext
,UsersContext
的类保留其范围时,才会打开该连接。
在您的示例中,UsersContext
的范围限定为using
块。
using (var context = new UsersContext())
{
//some actions
}
因此,一旦“某些操作”完成,连接将关闭,任何访问延迟加载的尝试都将抛出异常,说明连接不再可用。每次需要访问数据库时,我都应该在我看来开始新的连接。您要确保的是,您只能实际访问数据库。确保您的查询已经过优化,这样您就不会多次访问数据库而不是一次性完成所有操作,因为这会影响您的性能。
作为旁注,使用块分解为:
try{
var context = new UsersContext();
//some actions
}finally{
context.Dispose();
}