#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
-
Basta! Italia 2009 - I'll be there!
-
Entity Framework e l'estendibilità del designer
-
Mostrare la WebCam in Silverlight
-
#165 - Personalizzare l'installazione di applicazioni ClickOnce
-
#122 - Ricercare nodi su più livelli in una struttura XML utilizzando LINQ to XML
-
#162 - Caricare un file XML da remoto tramite XDocument e HttpWebRequest
-
#125 - Scaricare un file FTP tramite FtpWebRequest
-
#128 - Caricare parzialmente un oggetto di dominio con Entity Framework
-
.NET Framework 4.0 beta 1: Workflow Foundation 4.0
-
#106 - Scoprire quali oggetti verranno persistiti sul database con Entity Framework
-
#110 - Ricercare un oggetto prima in memoria e poi sul database con Entity Framework
-
#164 - Eseguire una stored procedure tramite l'Entity Client di Entity Framework

















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