多个DbContext,多个Database.SetInitializer

Mic*_*ael 8 asp.net-mvc entity-framework-4

我创建了两个DbContexts,一个用于应用程序配置,第二个用于日志记录.

原因是,我想在日志记录数据库上设置最大大小,这样就不会耗尽所有可用磁盘空间并阻止其他数据库工作.

在我的global.asax.cs文件中,我有以下内容:

        protected void Application_Start()
    {

        AreaRegistration.RegisterAllAreas();

        RegisterGlobalFilters(GlobalFilters.Filters);
        RegisterRoutes(RouteTable.Routes);

        Database.SetInitializer<AdminContext>(new AdminInitialiser());
        Database.SetInitializer<LoggingContext>(new LoggingInitialiser());
    }
Run Code Online (Sandbox Code Playgroud)

未调用LoggingInitialiser中的InitializeDatabase方法.这是因为只能设置一个初始值设定项吗?有没有办法让两个DbContexts的初始化器?

dan*_*wig 8

而是在DbContext构造函数中设置初始化程序.

public class AdminContext : DbContext
{
    public AdminContext()
    {
        Database.SetInitializer(new AdminInitialiser());
    }
}

public class LoggingContext : DbContext
{
    public LoggingContext()
    {
        Database.SetInitializer(new LoggingInitialiser());
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 是否存在多次被调用的风险?我怀疑初始化是昂贵的,即使部署没有变化.如果你把它放在静态构造函数中怎么样,这意味着它只会被调用一次? (3认同)