После документации от Microsoft
https://docs.microsoft.com/en-us/aspnet/core/data/ef-mvc/intro
Если вы используете инъекции зависимостей, во-первых, вам нужно настроить статический класс Data/DbInitializer.cs и введите следующий код:
public static class DbInitializer
{
public static void Initialize(ApplicationDbContext context)
{
context.Database.Migrate();
// Add Seed Data...
}
}
Обратите внимание, что вы также можете добавить данные о семенах.
Далее в файле Program.cs, добавьте следующий код
public static void Main(string[] args)
{
var host = BuildWebHost(args);
using (var scope = host.Services.CreateScope())
{
var services = scope.ServiceProvider;
try
{
var environment = services.GetRequiredService<IHostingEnvironment>();
if (!environment.IsDevelopment())
{
var context = services.GetRequiredService<ApplicationDbContext>();
DbInitializer.Initialize(context);
}
}
catch (Exception ex)
{
var logger = services.GetRequiredService<ILogger<Program>>();
logger.LogError(ex, "An error occurred while seeding the database.");
}
}
host.Run();
}
В моем случае, я проверяю окружение, чтобы убедиться, что я нахожусь в разработке, так что я могу контролировать Перемещения/обновления , Однако в производстве я хочу, чтобы они были автоматическими для непрерывной интеграции. Как отмечали другие, это, вероятно, не лучшие практики, но на небольших проектах он отлично работает.
Это называется EntityFramework ядра 1,0, благодаря – Tseng