【问题标题】:Where is DbContext.Database.Migrate() method?DbContext.Database.Migrate() 方法在哪里?
【发布时间】:2020-06-10 09:17:57
【问题描述】:

我打算在启动时调用此方法,但它在任何地方都没有引用:

dbContext.Database.Migrate();

类型DatabaseFacade 不包含Migrate 的定义并且没有 可以找到DatabaseFacade 类型的扩展方法Migrate(您是否缺少 using 指令还是程序集引用?

那么我缺少哪个使用/组装?

【问题讨论】:

  • 你有 `using Microsoft.EntityFrameworkCore;?如果使用 Sql Server Db,请确保您已安装 Microsoft.EntityFrameworkCore.SqlServer

标签: c# entity-framework-migrations dbcontext ef-core-3.0


【解决方案1】:
var migrator = dbContext.Database.GetService<IMigrator>();
await migrator.MigrateAsync("targetMigration", cancellationToken);

【讨论】:

  • 这如何回答这个问题?
【解决方案2】:

通过 NuGet 添加 Microsoft.EntityFrameworkCore.SqlServer 为我解决了这个问题。

【讨论】:

    【解决方案3】:

    (For.Net Core) 添加包后(Oracle/SQLServer) enter image description here

    您可以使用扩展设计像这样的 startup.cs。

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
        app
            .UseSwaggerUI()
            .UseRouting()
            .UseCors(options => options
                .AllowAnyOrigin()
                .AllowAnyHeader()
                .AllowAnyMethod())
            .UseAuthentication()
            .UseAuthorization()
            .UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
            })
            .ApplyMigrations();
    }
    

    所以你可以如下调用 ApplyMigrations。

    using Microsoft.AspNetCore.Builder;
    using Microsoft.EntityFrameworkCore;
    using Microsoft.Extensions.DependencyInjection;
    
    namespace SocialRebate.WebApi.Infrastructure.Extensions
    {
        public static class ApplicationBuilderExtensions
        {
            public static IApplicationBuilder UseSwaggerUI(this IApplicationBuilder app)
                => app
                    .UseSwagger()
                    .UseSwaggerUI(options =>
                    {
                        options.SwaggerEndpoint("/swagger/v1/swagger.json", "Your API");
                        options.RoutePrefix = string.Empty;
                    });
    
            public static void ApplyMigrations(this IApplicationBuilder app)
            {
                using var services = app.ApplicationServices.CreateScope();
    
                var dbContext = services.ServiceProvider.GetService<YourDbContext>();
    
                dbContext.Database.Migrate();
            }
        }
    }
    

    【讨论】: