La novità più attesa in Entity Framework 5 è sicuramente la possibilità di mappare una proprietà che rappresenta un enum. Vediamo in questo script come sia ora semplice utilizzare questa funzionalità.
Il primo passo è definire l'enum e in questo caso creiamo un enum che rappresenta il sesso di una persona.
public enum Gender{
Male,
Female
}Una volta definito l'enum, creiamo una classe di cui una proprietà sia del tipo dell'enum. In questo caso creiamo una classe Person che ha una proprietà sesso di tipo Gender.
public class Person{
public int Id {get; set; }
public Gender Gender {get; set; }
}Ora che abbiamo la classe, non ci rimane che creare la classe di contesto che mappa la classe sul database.
public partial class PersonContext : DbContext {
public DbSet<Person> People { get; set; }
}A questo punto, grazie a Entity Framework 5, la proprietà Gender è mappata sul database come una colonna di tipo int e sarà sempre Entity Framework 5 a occuparsi della conversione da int ad enum, quando eseguiamo una query, e da enum a int, quando persistiamo l'oggetto. Ovviamente, possiamo anche eseguire query che ordinano, filtrano, raggruppano (e così via), in base alla proprietà di tipo enum:
var males = ctx.People.Where(p => p.Gender == Gender.Male);
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare la libreria PredicateBuilder per eseguire query tramite Entity Framework che usano or su più campi
Creare espressioni riutilizzabili nelle query LINQ per Entity Framework
Potenziare la ricerca su Cosmos DB con Full Text Search
Creare comandi nella dashboard .NET Aspire
Mischiare codice server side e client side in una query LINQ con Entity Framework
Utilizzare il metodo ExceptBy per eseguire operazione di sottrazione tra liste
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Importare un servizio esterno in .NET Aspire
Esporre tool MCP con Azure Functions
Loggare le query più lente con Entity Framework
Controllare la velocità di spostamento su una pagina HTML
Integrare SQL Server in un progetto .NET Aspire


