Utiliser plusieurs clauses Where dans une requête LINQ

This article is available in English.

Pour faire suite à mon précédent article où j'avais besoin d'être capable d'intercepter les exceptions dans une requête, j'ai constaté qu'il est possible de spécifier plusieurs clauses Where dans une requête LINQ.

Voici la requête en question :

var q = from file in Directory.GetFiles(@"C:\Windows\Microsoft.NET\Framework\v2.0.50727", "*.dll")
        let asm = file.TryWith(f => Assembly.LoadFile(f))
        where asm != null
        let types = asm.TryWith(a => a.GetTypes(), (Exception e) => new Type[0])
        where types.Any()
        select new { asm, types };


Cette requête permet de trouver la liste des assemblies pour lesquelles il est possible d'en lister les types. L'intéret de placer plusieurs clause where est de ne pas avoir à évaluer inutilement des morceaux d'une query, si les morceaux précédents permettent de le savoir. Au passage, le TryWith autour du Assembly.GetTypes() est la pour intercepter des exceptions de chargement de types, au cas où des dependances ne seraient pas disponibles au moment de l'énumération.

C'est une petite astuce LINQ à savoir :)
Publié samedi 6 décembre 2008 22:19 par jay
Classé sous , , ,
Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :

Commentaires


Les 10 derniers blogs postés

- [RIA Services] Include et DomainDataSource par Blog Technique d'Audrey PETIT le il y a 8 heures et 16 minutes

- ZUNE : Version ZUNE Software V 4.2 et la socialisation par Blog Technique de Romelard Fabrice le il y a 9 heures et 41 minutes

- Pratique de Silverlight par Eric Ambrosi par Blog de Frédéric Queudret le il y a 11 heures et 48 minutes

- Apprendre à développer pour les mobiles avec la nouvelle génération .NET par Perspective le il y a 13 heures et 4 minutes

- ZUNE : Nouvelle version du ZUNE Software – V 4.2 par Blog Technique de Romelard Fabrice le il y a 13 heures et 29 minutes

- Nouveau système d'aide pour Visual Studio 2010 : pour ceux qui n'apprécient pas trop l'absence d'index... par CoqBlog le 03-20-2010, 20:05

- L'interface naturelle de Windows Phone 7 Series par Perspective le 03-20-2010, 18:49

- Comment mapper une vue SQL sur une collection de complex type? par Matthieu MEZIL le 03-19-2010, 21:05

- SQL Server : Query Notification ou comment être notifié de modifications de données côté application (SqlDependency) par SQL Server vu par Christian Robert le 03-19-2010, 15:06

- [WF4] Un Binding Activity/ActivityDesigner qui passe mal? par Blog de Jérémy Jeanson le 03-19-2010, 13:42