Quando si esegue una query con LINQ, il risultato viene messo in una lista di oggetti (a meno che non si tratti di query con Max, Count, ecc. ecc.). Molto spesso, però, si ha l'esigenza di recuperare un solo oggetto e quindi torna utile avere a disposizione un meccanismo che permetta di avere direttamente l'oggetto e non una lista con un solo elemento.
In situazioni del genere, si può usare il metodo Single che copre esattamente questa esigenza.
List<string> letters = new List<string> { "a", "b", "c", "d", "e", "f", "g", "h", "i" }; var q = (from letter in letters where letter == "b" select letter).Single();
E' molto importante sottolineare il fatto che nel caso la query non restituisse nessun oggetto o ne restituisse più di uno, la chiamata al metodo Single causerebbe una InvalidOperationException.
Per approfondimenti si veda:
#34 - Verificare che tutti gli oggetti in una lista soddisfino una condizione con la clausola All di LINQ
https://www.linqitalia.com/script/34/Verificare-Oggetti-Lista-Soddisfino-Condizione-Clausola-All-LINQ.aspx
#32 - Paginare i risultati di una query LINQ con Skip e Take
https://www.linqitalia.com/script/32/Paginare-Risultati-Query-LINQ-Skip-Take.aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.