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.
Approfondimenti
I più letti di oggi
- Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
- Utilizzare StartsWith ed EndsWith con Span
- Utilizzare l nesting nativo dei CSS
- Microsoft lancia il nuovo tool gratuito 'ASP.NET Web Matrix Project'
- Managed deployment strategy in Azure DevOps
- Forzare l'apertura di un file fuori dal browser
- Configurare e gestire sidecar container in Azure App Service