Подтвердить что ты не робот

Entity Framework Code - первые данные по умолчанию в базе данных

Как мне обрабатывать ситуации, в которых мне нужны предварительно существующие данные, прежде чем приложение будет запущено или сразу после создания базы данных. Например, у меня есть список стран, в которые я хотел бы загрузиться в базу данных после первого генерирования кода. Как это сделать?

Приложение структурировано следующим образом:

Repository > Service > WebMVC

xml находится в проекте WebMVC.

4b9b3361

Ответ 1

Создается пользовательский инициализатор, который наследует интерфейс DropCreateDatabaseIfModelChanges или DropCreateDatabaseAlways. Как:

public class EntitiesContextInitializer : DropCreateDatabaseIfModelChanges<-YourDbContext->

И затем вы перезаписываете метод Seed, например:

protected override void Seed(YourDbContext context)

Весь пример может выглядеть так:

public class EntitiesContextInitializer : DropCreateDatabaseIfModelChanges<EntitiesContext>
{
    protected override void Seed(EntitiesContext context)
    {
        List<Role> roles = new List<Role>
        {
            new Role {Id=1, Title="Admin"},
            new Role {Id=2, Title="ProjectManager"},
            new Role {Id=3, Title="Developer"}
        };

        // add data into context and save to db
        foreach (Role r in roles)
        {
            context.Roles.Add(r);
        }
        context.SaveChanges();

    }
}

Изменить: после установки этого параметра вы также должны установить Инициализатор, как отметил Ладислав Мрнка.

Database.SetInitializer(new EntitiesContextInitializer());

т.е..: в Global.asax:

protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();
    RegisterGlobalFilters(GlobalFilters.Filters);
    RegisterRoutes(RouteTable.Routes);
    Database.SetInitializer(new EntitiesContextInitializer());
}

Не забудьте добавить using System.Data.Entity; .....

Ответ 2

Вы должны создать собственный инициализатор базы данных, полученный, например, из DropCreateDatabaseIfModelChanges и заполнить данные с помощью метода overriden Seed. Затем вы должны использовать Database.SetInitializer для установки нового инициализатора при запуске приложения. Здесь приведен пример (из CTP5), используемый для создания пользовательского индекса в базе данных.