проблема с созданием моего контекста при добавлении миграции

#c# #.net #asp.net-mvc-4 #asp.net-core-mvc #entity-framework-migrations

#c# #.net #asp.net-mvc-4 #asp.net-core-mvc #entity-framework-миграции

Вопрос:

Я уже некоторое время работаю над проектом, и мне удалось без проблем добавлять миграции, но неделю или две назад я перешел от использования
onconfiguring optionsbuilder.useSqlServer для подключения к sql server из моего класса контекста к использованию сервисов из Startup class для подключения к базе
данных. При попытке запустить add-migration яполучить эту ошибку
Невозможно создать объект типа ‘mojDbContext’. Для разных шаблонов, поддерживаемых во время разработки

Класс программы

  public class Program
{
   
    
    
    
    public static void Main(string[] args)
    {
        CreateHostBuilder(args).Build().Run();
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup<Startup>();
            });
}
  

класс запуска

  public class Startup
{
    public IConfiguration Configuration { get; }
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }

   

    // This method gets called by the runtime. Use this method to add services to the container.
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddDbContext<mojDbContext>(options=> options.UseSqlServer(Configuration.GetConnectionString("ererer")));
        services.AddControllersWithViews();

        services.AddMvc();
        services.AddDistributedMemoryCache();
        services.AddSession();
    }

    // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
        else
        {
            app.UseExceptionHandler("/Home/Error");
            // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
            app.UseHsts();
        }
        app.UseSession();
        app.UseHttpsRedirection();
        app.UseStaticFiles();

        app.UseRouting();

        app.UseAuthorization();

        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllerRoute(
                name: "default",
                pattern: "{controller=Home}/{action=Index}/{id?}");
        });
    }
}
  

мой класс контекста с удаленными свойствами dbset для уменьшения размера кода

  public class mojDbContext : DbContext
{
    

   
    public mojDbContext(DbContextOptions<mojDbContext> options)
        : base(options)
    {
    }



}
  

когда я запускаю add-migration -verbose, я получаю это

https://i.stack.imgur.com/Rn7Op.png

Комментарии:

1. Вы обновили EF? Начиная с определенной версии, вам нужен ctor без параметров для миграции. И для этого какой-то запасной код в OnConfiguring.

2. у меня установлен целевой фреймворк netcoreapp3.1, ничего не обновлял