Per generare il DbContext e le classi di mapping verso il database, Entity Framework Core mette a disposizione il commando Scaffold-DbContext da lanciare nella finestra "Package Manager Console". Quando usiamo questo comando, Entity Framework genera (per default) una classe per ogni tabella nel database creando nella classe una proprietà per ogni colonna nella tabella. Per creare i nomi di classi e colonne, Entity Framework Core utilizza internamente delle convenzioni che non sono modificabili.
Non mantenere i nomi originali può non essere un problema in alcuni casi, ma in altri può esserlo. Utilizzando dell API interne, possiamo istruire Entity Framework Core per non alterare i nomi di tabelle e colonne. Per fare questo dobbiamo innanzitutto creare le seguenti due classi nell'assmbly in cui vogliamo enerare il codice.
public class ScaffoldingDesignTimeServices : IDesignTimeServices { public void ConfigureDesignTimeServices(IServiceCollection services) { services.AddTransient<ICandidateNamingService, ScaffoldingCandidateNamingService>(); } } public class ScaffoldingCandidateNamingService : CandidateNamingService { public override string GenerateCandidateIdentifier(string original) { return original; } }
La classe ScaffoldingDesignTimeServices configura nel motore di DI di .NET Core la classe ScaffoldingCandidateNamingService come responsabile della creazione del nome di classi e proprietà. Questa classe riceve in input il nome originale di tabelle e colonne dal database e ritorna il valore senza modificarlo.
Il secondo step consiste nell'impostare il progetto come progetto di startup in Visual Studio 2017.
Il terzo e ultimo step consiste nell'invocare il commando Scaffold-DbContext.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare form tipizzati con Angular
Gestire i null nelle reactive form tipizzate di Angular
Registrare servizi multipli tramite chiavi in ASP.NET Core 8
Sfruttare al massimo i topic space di Event Grid MQTT
Utilizzare l'operatore GroupBy come ultima istruzione di una query LINQ in Entity Framework
Utilizzare la session affinity con Azure Container Apps
Limitare le richieste lato server con l'interactive routing di Blazor 8
Eseguire attività pianificate con Azure Container Jobs
Sfruttare i KeyedService in un'applicazione Blazor in .NET 8
Gestire undefined e partial nelle reactive forms di Angular
Gestire domini wildcard in Azure Container Apps
Determinare lo stato di un pod in Kubernetes
I più letti di oggi
- Elencare gli utenti di un dominio NT con ADSI
- Creare un messaggio di posta in diversi formati con ASP.NET 2.0
- Utilizzare SQL e #linq per eseguire una query con #entityframework Core https://aspit.co/bfv di @sm15455 #efcore1
- Utilizzare il metodo reduce in #javascript https://aspit.co/ccc di @morwalpiz
- Disponibile il codice sorgente di ASP.NET MVC
- rilasciati nuovi template per la #aspnet web pages. funzionano anche con #webmatrix: http://u.aspitalia.com/lu