【问题标题】:Unable to create migrations on EF Core 6无法在 EF Core 6 上创建迁移
【发布时间】:2022-02-25 01:01:14
【问题描述】:

我在运行dotnet ef migrations add Initial 时遇到了这个问题,我不知道是什么原因造成的。问题是我收到以下错误:

无法创建“ApplicationDbContext”类型的对象。有关设计时支持的不同模式,请参阅https://go.microsoft.com/fwlink/?linkid=851728

我一直在检查代码,我找不到问题。

这是我的Program.cs 代码:

using Microsoft.EntityFrameworkCore;
using TrainningManagerService.Context;

var builder = WebApplication.CreateBuilder(args);

// Add services to the container.

builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();

var app = builder.Build();

// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
    app.UseSwagger();
    app.UseSwaggerUI();
}

var connectionString = builder.Configuration.GetConnectionString("DefaultConnection");
builder.Services.AddDbContext<ApplicationDbContext>(options =>
{
    options.UseMySql(connectionString, ServerVersion.AutoDetect(connectionString));
});

app.UseHttpsRedirection();

app.UseAuthorization();

app.MapControllers();

app.Run();

这是我的ApplicationDbContext

using Microsoft.EntityFrameworkCore;
using TrainningManagerService.Entities.Database;

namespace TrainningManagerService.Context
{
    public class ApplicationDbContext : DbContext
    {
        public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options) :
            base(options)
        {
        }

        public DbSet<Video> Videos { get; set; }
        public DbSet<Plan> Plans { get; set; }
    }
}

我已经在互联网上四处寻找,但在任何地方都找不到解决方案,这真的让我很困扰,因为我刚刚创建了一个新的解决方案,但我无法创建一个迁移。

【问题讨论】:

  • 我认为您没有连接到数据库。最近有类似的问题。
  • 不适用于 EF Core 6,但使用先例版本,在控制台应用程序中,您需要覆盖上下文类中的 OnConfiguring 方法。看到这个answer

标签: c# entity-framework-core .net-6.0 ef-core-6.0


【解决方案1】:

这是由 Program.cs 中的顺序引起的。

我不得不向上移动这部分:

var connectionString = builder.Configuration.GetConnectionString("DefaultConnection");
builder.Services.AddDbContext<ApplicationDbContext>(options =>
{
    options.UseMySql(connectionString, ServerVersion.AutoDetect(connectionString));
});

所以变成了:

var builder = WebApplication.CreateBuilder(args);

// Add services to the container.

builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();

var connectionString = builder.Configuration.GetConnectionString("DefaultConnection");
builder.Services.AddDbContext<ApplicationDbContext>(options =>
{
    options.UseMySql(connectionString, ServerVersion.AutoDetect(connectionString));
});

var app = builder.Build();

否则,构建器在应用数据库之前就已经完成

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-12-25
    • 2021-12-28
    • 2017-05-29
    • 2022-01-15
    • 2022-07-15
    • 1970-01-01
    • 2021-12-29
    • 2021-10-14
    相关资源
    最近更新 更多