Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Multiple DbContext, multiple Database.SetInitializer

I have created two DbContexts, one is for application configuration, the second is for logging.

The reason being, I want to set a maximum size on the logging db so it doesn't use up all free disk space and prevent other databases from working.

In my global.asax.cs file, I have the following:

        protected void Application_Start()
    {

        AreaRegistration.RegisterAllAreas();

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

        Database.SetInitializer<AdminContext>(new AdminInitialiser());
        Database.SetInitializer<LoggingContext>(new LoggingInitialiser());
    }

The InitializeDatabase method in LoggingInitialiser is not being called. Is this because only one initializer can be set? Is there any way to have initializers for two DbContexts?

like image 842
Michael Avatar asked Jun 25 '12 13:06

Michael


3 Answers

Set the initializer in the DbContext constructor instead.

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

public class LoggingContext : DbContext
{
    public LoggingContext()
    {
        Database.SetInitializer(new LoggingInitialiser());
    }
}
like image 135
danludwig Avatar answered Oct 23 '22 21:10

danludwig


Yes you can do it. You just need to initialize before you move on to the next one.

  Database.SetInitializer<MyDBContext>(myInitializer);
  MyDbContext context = new MyDbContext();
  context.Database.Initialize(false);

  Database.SetInitializer<MySecondDBContext>(myInitializer);
  MySecondDbContext context2 = new MySecondDbContext();
  context2.Database.Initialize(false);

Note: that I usually get the DbContext instance from a dependency resolver...

like image 23
Sylvia Avatar answered Oct 23 '22 22:10

Sylvia


I suggest to put the SetInitializer call to static constructor like below:

    static ApplicationIdentityDbContext()
    {
        Database.SetInitializer(new IdentityDbInitializer());
    }

Below is from MSDN

A static constructor is used to initialize any static data, or to perform a particular action that needs to be performed once only. It is called automatically before the first instance is created or any static members are referenced.

So static constructor is ideal for initialize database. I have used this technique for multiple database and it works well for me.

like image 41
Yang Zhang Avatar answered Oct 23 '22 23:10

Yang Zhang