Seed Database at Application Start - ASP MVC 3 and EF

自古美人都是妖i 提交于 2019-12-01 06:14:48
Jim Wolff

First off, all your EF code looks fine.

The problem is, you have initialize your database. Otherwise EF will wait until you access it in some way to initialize it.

You could navigate your website as much as you want without the database even starting up, if none of the pages access the data.

If you want to force the database to initialize when the application starts, do something like this:

using (var db = new LocatorContext())
{
    db.Database.Initialize(true);
}

I usually i create a static class like:

public static class LocatorInitializationHandler
{
    public static void Initialize()
    {
        // if you want to use your initializer
        Database.SetInitializer(new CreateInitializer()); 

        using (var db = new LocatorContext())
        {
            db.Database.Initialize(true);
        }
    }
}

Which i can then call from App_start:

//Global.asax.cs
protected void Application_Start()
{
    LocatorInitializationHandler.Initialize();

    AreaRegistration.RegisterAllAreas();
    RegisterGlobalFilters(GlobalFilters.Filters);
    RegisterRoutes(RouteTable.Routes);
}
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!