LINQ to XML est relativement facile à implémenter pour lire de gros fichiers et pour requêter des fichiers XML.
Par exemple, considérons ce fichier XML :
<?xml version="1.0" encoding="utf-8" ?> <users> <user name="User1" groupid="4" /> <user name="User2" groupid="1" /> <user name="User3" groupid="3" /> <user name="User4" groupid="1" /> <user name="User5" groupid="1" /> <user name="User6" groupid="2" /> <user name="User7" groupid="1" /> </users>
Supposons que vous souhaitez trouver tous les enregistrements avec groupid > 2. Vous pouvez être tenté d’implémenter la requête suivante :
XElement doc = XElement.Load("users.xml"); var users = from u in doc.Elements("user") where u.Attribute("groupid") != null && int.Parse(u.Attribute("groupid").Value) > 2 select u; Console.WriteLine("{0} users match query", users.Count());
Il y a un piège dans cette implémentation. La méthode XElement.Load va lire tout le fichier XML en mémoire avant de s’exécuter, et ce fichier peut être très gros.