DbContext Not Found o Un archivio relazionale è stato configurato senza specificare la DbConnection o la stringa di connessione da utilizzare

asp.net-core asp.net-core-mvc entity-framework-core

Domanda

quando si utilizzano i comandi di Entity Framework ("7.0.0-beta1").

durante la corsa

k ef migration aggiunge InitialCreate

sto ricevendo errori.

[Soluzione]

Cerco di spostare il mio file di classe (dove DbContext è stato creato) al progetto principale da una libreria di classi separata e tutto funziona come previsto.

quindi il vero problema è quando si utilizza DbContext in una libreria di classi separata.

il mio file dbcontext

public class DbTables : DbContext
{

    public DbSet<class_name> class_name_alias { get; set; }

    private static bool _created = false;

    public DbTables()
    {
        if (_created)
        {
            Database.AsRelational().ApplyMigrations();
            _created = true;
        }
    }

    protected override void OnConfiguring(DbContextOptions options)
    {
        options.UseSqlServer(@"Data Source=(LocalDB)\MSSQLLocalDB;Initial Catalog=app_db;Integrated Security=True;Connect Timeout=30;Encrypt=False;TrustServerCertificate=False");
    }

    protected override void OnModelCreating(ModelBuilder builder)
    {
        base.OnModelCreating(builder);
    }

}

Risposta accettata

Se si crea un DBContext in una libreria di classi, per creare la migrazione è necessario dichiarare il comando ef nel project.json di questa libreria di classi. ed esegui il comando k ef per questo progetto.

{
    "version": "1.0.0-*",
    "dependencies": {
        "EntityFramework.SqlServer": "7.0.0-beta1",
        "EntityFramework.Commands": "7.0.0-beta1" 
    },
    "commands": {
        "ef": "EntityFramework.Commands"
    },
    "frameworks" : {
        "aspnet50" : { 
            "dependencies": {
            }
        },
        "aspnetcore50" : { 
            "dependencies": {
                "System.Runtime": "4.0.20-beta-22231"
            }
        }
    }
}

È necessario eseguire l'override del metodo OnConfiguring on per impostare una stringa di connessione

protected override void OnConfiguring(DbContextOptions options)
{
    options.UseSqlServer(@"Data Source=(LocalDB)\MSSQLLocalDB;Initial Catalog=app_db;Integrated Security=True;Connect Timeout=30;Encrypt=False;TrustServerCertificate=False");
}


Related

Autorizzato sotto: CC-BY-SA with attribution
Non affiliato con Stack Overflow
È legale questo KB? Sì, impara il perché
Autorizzato sotto: CC-BY-SA with attribution
Non affiliato con Stack Overflow
È legale questo KB? Sì, impara il perché