Ho creato la classe DataContect che è ereditata dalla classe IdentityDbContext:
using ProjDAL.Entities;
using ProjDAL.Relations;
using ProjDAL.Services;
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Design;
using Microsoft.Extensions.Configuration;
namespace ProjDAL.EF
{
public class DataContext : IdentityDbContext<ApplicationUser>
{
public DataContext(DbContextOptions<DataContext> options) : base(options)
{
}
protected override void OnModelCreating(ModelBuilder builder)
{
base.OnModelCreating(builder);
}
.......................................................
}
La soluzione ha un'applicazione console in cui creo un nuovo DataContext:
using System;
using DbInitialize.Interface;
using ProjDAL.EF;
namespace DbInitialize.Provider
{
public class DbInitializeProvider : IDbInitialize
{
private DataContext _db;
public DbInitializeProvider()
{
_db = new DataContext(options => options.UseSqlServer("Data Source=.\\SQLEXPRESS;Initial Catalog=ProjAppTest;Integrated Security=True;MultipleActiveResultSets=true"));
}
public void SetCreateDatabase()
{
Console.WriteLine("Check for database availability: ");
using (var transaction = _db.Database.BeginTransaction())
{
try {
if(_db.Database != null)
{
Console.WriteLine("Done!\r\n");
}
else
{
_db.Database.EnsureCreated();
Console.WriteLine("Database was created!\r\n");
}
transaction.Commit();
}
catch (DbException error)
{
Console.WriteLine(error);
transaction.Rollback();
}
}
}
}
}
Il mio file Program.cs:
using System;
using DbInitialize.Provider;
using ProjDAL.EF;
namespace DbInitialize
{
class Program
{
private static readonly DbInitializeProvider _db;
delegate void Display();
static Program()
{
_db = new DbInitializeProvider();
}
static void Main(string[] args)
{
try
{
Display display = _db.SetCreateDatabase;
display.Invoke();
Console.WriteLine($"\r\n{new string('-', 80)}");
Console.WriteLine("For continue press any button...");
}
catch (Exception e)
{
Console.WriteLine(e);
}
Console.ReadLine();
}
}
}
Ottengo l'errore: Impossibile convertire l'espressione lambda per digitare "DbContextOptions" perché non è un tipo delegato Come è corretto creare un'istanza DataContext e impostare i parametri delle opzioni?
Se hai bisogno di ulteriori informazioni, per favore dimmi. Grazie per il tuo aiuto.
Quando si crea la classe DataContext
, il parametro non corrisponde a ciò che è stato definito nel costruttore DataContext
. Si aspetta un oggetto di tipo DbContextOptions<DataContext>
Ma stai fornendo un'azione con un parametro options => options.UseSqlServer("Data Source=.\\SQLEXPRESS;Initial Catalog=ProjAppTest;Integrated Security=True;MultipleActiveResultSets=true")
È necessario creare l'oggetto options e fornire l'istanza al costruttore:
var optionsBuilder = new DbContextOptionsBuilder<DataContext>();
optionsBuilder.UseSqlServer("YOUR CONNECTION STRING");
_db = new DataContext(optionsBuilder.Options)
In alternativa, è possibile utilizzare il costruttore senza argomenti e configurarlo nella classe DataContext
nel metodo OnConfiguring
.
Vedere la documentazione qui: https://docs.microsoft.com/en-us/ef/core/miscellaneous/configuring-dbcontext