Quando mappiamo il nostro modello verso il database, ci sono moltissime cose a cui dobbiamo prestare attenzione come la lunghezza dei campi di tipo string, il tipo che vogliamo assegnare alle proprietà di tipo Datetime e altro ancora. Molto spesso queste impostazioni sono uguali per tutte le proprietà come il fatto che le stringhe devono essere tutte non unicode, che i value type convertiti in JSON hanno lo stesso mapping e così via. In queste situazioni può tornare utile specificare un mapping non per proprietà, ma globalmente per il tipo.
A partire da Entity Framewok Core 6, possiamo specificare queste convenzioni eseguendo l'override del metodo ConfigureConventions della classe DbContext così come mostrato nell'esempio.
protected override void ConfigureConventions(ModelConfigurationBuilder configurationBuilder) { configurationBuilder .Properties<string>() .AreUnicode(false) .HaveMaxLength(1024); }
In questo esempio, con il metodo Properties specifichiamo che tutte proprietà di tipo string hanno una lunghezza di 1024 caratteri e non sono unicode. Ovviamente se impostiamo questi stessi parametri di mapping in una proprietà di una entity, quelli di default vengono sovrascritti. Per fare un esempio, se sulla proprietà Nome dell'entity Persona impostiamo una lunghezza di 50, verrà usata quella e non quella 1024.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire script pre e post esecuzione di un workflow di GitHub
Utilizzare QuickGrid di Blazor con Entity Framework
Gestire i dati con Azure Cosmos DB Data Explorer
Usare le navigation property in QuickGrid di Blazor
Utilizzare Azure AI Studio per testare i modelli AI
Applicare un filtro per recuperare alcune issue di GitHub
Il nuovo controllo Range di Blazor 9
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Supportare la sessione affinity di Azure App Service con Application Gateway
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API
Selettore CSS :has() e i suoi casi d'uso avanzati