#126 - Simulare la clausola Single con Entity Framework
di Stefano Mostarda, in LINQ, Entity Framework, 10 giugno 2009
Quando si deve selezionare un solo record con Entity framework, si deve ricorrere al metodo Top della classe ObjectQuery o al metodo First di LINQ To Entities. Tuttavia, questi metodi restituiscono solamente il primo record trovato a prescindere da quanti effettivamente corrispondono ai criteri di ricerca. Se si vuole essere certi che una query ritorni un solo elemento, LINQ mette a disposizione l'operatore Single.
Questo operatore non è supportato in Entity Framework 1.0, ma lo sarà nella versione 4.0. Se tuttavia si vuole simulare questo comportamento da subito e lanciare un'eccezione se la query contiene più di un elemento, possiamo sfruttare il metodo Take estraendo solo i primi 2 record. In questo modo, se la query torna 2 record, possiamo sollevare un'eccezione.
var c = ctx.Orders.Where(o => 0.OrderNumber == 1).Take(2); if (c.Count() == 2) throw new Exception("E' stato recuperato più di un record"); else var obj = c.First();
Questo meccanismo, è lo stesso che viene utilizzato da Entity Framework 4.0.
Approfondimenti
-
#145 - Eseguire un servizio WCF con privilegi minimi
-
#129 - Ruotare la camera di una scena 3D di WPF con il mouse
-
#139 - Invocare servizi in asincrono con WCF
-
#103 - Caricare facilmente le risorse degli assembly con il prefisso pack://
-
Entity Framework 4.0 finalmente ha un buon designer
-
Parallelizzare in Silverlight 2.0
-
#987 - La gestione della cache con il controllo LinqDataSource di ASP.NET 3.5
-
.NET Framework 4.0 Beta 1: Parallel FX
-
Entity Framework ed NHibernate a confronto
-
#123 - Intercettare gli eventi del serializzatore WCF
-
#157 - Serializzare e deserializzare in JSON con DataContractJsonSerializer
-
#159 - Gestire code di operazioni con un Dispatcher personalizzato

















Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.