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
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core
Gestire codice JavaScript con code splitting e lazy loading
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
Generare una User Delegation SAS in .NET per Azure Blob Storage
Gestire il routing HTTP in Azure Container App
Il nuovo controllo Range di Blazor 9
Ottimizzare le pull con Artifact Cache di Azure Container Registry