LINQ - Guide rapide
Les développeurs du monde entier ont toujours rencontré des problèmes lors de l'interrogation des données en raison de l'absence de chemin défini et doivent maîtriser plusieurs technologies comme SQL, les services Web, XQuery, etc.
Introduit dans Visual Studio 2008 et conçu par Anders Hejlsberg, LINQ (Language Integrated Query) permet d'écrire des requêtes même sans la connaissance des langages de requête comme SQL, XML, etc. Les requêtes LINQ peuvent être écrites pour divers types de données.
Exemple de requête LINQ
C #
using System;
using System.Linq;
class Program {
static void Main() {
string[] words = {"hello", "wonderful", "LINQ", "beautiful", "world"};
//Get only short words
var shortWords = from word in words where word.Length <= 5 select word;
//Print each word out
foreach (var word in shortWords) {
Console.WriteLine(word);
}
Console.ReadLine();
}
}
VB
Module Module1
Sub Main()
Dim words As String() = {"hello", "wonderful", "LINQ", "beautiful", "world"}
' Get only short words
Dim shortWords = From word In words _ Where word.Length <= 5 _ Select word
' Print each word out.
For Each word In shortWords
Console.WriteLine(word)
Next
Console.ReadLine()
End Sub
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
hello
LINQ
world
Syntaxe de LINQ
Il existe deux syntaxes de LINQ. Ce sont les suivants.
Syntaxe Lamda (méthode)
var longWords = words.Where( w ⇒ w.length > 10);
Dim longWords = words.Where(Function(w) w.length > 10)
Syntaxe de requête (compréhension)
var longwords = from w in words where w.length > 10;
Dim longwords = from w in words where w.length > 10
Types de LINQ
Les types de LINQ sont mentionnés ci-dessous en bref.
- LINQ aux objets
- LINQ vers XML (XLINQ)
- LINQ vers DataSet
- LINQ vers SQL (DLINQ)
- LINQ vers les entités
En dehors de ce qui précède, il existe également un type LINQ nommé PLINQ qui est le LINQ parallèle de Microsoft.
Architecture LINQ dans .NET
LINQ a une architecture à 3 couches dans laquelle la couche supérieure se compose des extensions de langage et la couche inférieure se compose de sources de données qui sont généralement des objets implémentant des interfaces génériques IEnumerable <T> ou IQueryable <T>. L'architecture est illustrée ci-dessous.
Expressions de requête
L'expression de requête n'est rien d'autre qu'une requête LINQ, exprimée sous une forme similaire à celle de SQL avec des opérateurs de requête tels que Select, Where et OrderBy. Les expressions de requête commencent généralement par le mot-clé "De".
Pour accéder aux opérateurs de requête LINQ standard, l'espace de noms System.Query doit être importé par défaut. Ces expressions sont écrites dans une syntaxe de requête déclarative qui était C # 3.0.
Vous trouverez ci-dessous un exemple pour montrer une opération de requête complète qui comprend la création d'une source de données, la définition d'une expression de requête et l'exécution d'une requête.
C #
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Operators {
class LINQQueryExpressions {
static void Main() {
// Specify the data source.
int[] scores = new int[] { 97, 92, 81, 60 };
// Define the query expression.
IEnumerable<int> scoreQuery = from score in scores where score > 80 select score;
// Execute the query.
foreach (int i in scoreQuery) {
Console.Write(i + " ");
}
Console.ReadLine();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
97 92 81
Méthodes d'extension
Introduites avec .NET 3.5, les méthodes d'extension sont déclarées uniquement dans des classes statiques et permettent l'inclusion de méthodes personnalisées aux objets pour effectuer des opérations de requête précises pour étendre une classe sans être un membre réel de cette classe. Ceux-ci peuvent également être surchargés.
En un mot, les méthodes d'extension sont utilisées pour traduire les expressions de requête en appels de méthode traditionnels (orientés objet).
Différence entre LINQ et procédure stockée
Il existe un éventail de différences entre les procédures LINQ et stockées. Ces différences sont mentionnées ci-dessous.
Les procédures stockées sont beaucoup plus rapides qu'une requête LINQ car elles suivent un plan d'exécution attendu.
Il est facile d'éviter les erreurs d'exécution lors de l'exécution d'une requête LINQ que par comparaison avec une procédure stockée, car la première prend en charge Intellisense de Visual Studio ainsi que la vérification de type complet lors de la compilation.
LINQ permet le débogage en utilisant le débogueur .NET, ce qui n'est pas le cas des procédures stockées.
LINQ offre une prise en charge de plusieurs bases de données contrairement aux procédures stockées, où il est essentiel de réécrire le code pour divers types de bases de données.
Le déploiement d'une solution basée sur LINQ est facile et simple par rapport au déploiement d'un ensemble de procédures stockées.
Besoin de LINQ
Avant LINQ, il était essentiel d'apprendre C #, SQL et diverses API qui lient les deux pour former une application complète. Depuis, ces sources de données et langages de programmation sont confrontés à un décalage d'impédance; un besoin de codage court se fait sentir.
Vous trouverez ci-dessous un exemple du nombre de techniques utilisées par les développeurs lors de l'interrogation d'une donnée avant l'avènement de LINQ.
SqlConnection sqlConnection = new SqlConnection(connectString);
SqlConnection.Open();
System.Data.SqlClient.SqlCommand sqlCommand = new SqlCommand();
sqlCommand.Connection = sqlConnection;
sqlCommand.CommandText = "Select * from Customer";
return sqlCommand.ExecuteReader (CommandBehavior.CloseConnection)
Fait intéressant, parmi les lignes de code présentées, la requête n'est définie que par les deux dernières. En utilisant LINQ, la même requête de données peut être écrite sous une forme de code couleur lisible comme celle ci-dessous mentionnée ci-dessous également en très moins de temps.
Northwind db = new Northwind(@"C:\Data\Northwnd.mdf");
var query = from c in db.Customers select c;
Avantages de LINQ
LINQ offre une foule d'avantages et parmi eux, le principal est sa puissante expressivité qui permet aux développeurs de s'exprimer de manière déclarative. Certains des autres avantages de LINQ sont indiqués ci-dessous.
LINQ propose une coloration syntaxique qui s'avère utile pour détecter les erreurs lors de la conception.
LINQ propose IntelliSense, ce qui signifie écrire facilement des requêtes plus précises.
L'écriture des codes est assez rapide dans LINQ et donc le temps de développement est également considérablement réduit.
LINQ facilite le débogage grâce à son intégration dans le langage C #.
L'affichage des relations entre deux tables est facile avec LINQ en raison de sa fonction hiérarchique, ce qui permet de composer des requêtes joignant plusieurs tables en moins de temps.
LINQ permet l'utilisation d'une seule syntaxe LINQ lors de l'interrogation de nombreuses sources de données diverses, principalement en raison de sa base unitive.
LINQ est extensible, ce qui signifie qu'il est possible d'utiliser la connaissance de LINQ pour interroger de nouveaux types de sources de données.
LINQ offre la possibilité de joindre plusieurs sources de données dans une seule requête et de décomposer des problèmes complexes en un ensemble de requêtes courtes faciles à déboguer.
LINQ offre une transformation facile pour la conversion d'un type de données en un autre, comme la transformation de données SQL en données XML.
Avant de commencer avec les programmes LINQ, il est préférable de comprendre d'abord les nuances de la configuration d'un environnement LINQ. LINQ a besoin d'un framework .NET, une plate-forme révolutionnaire pour avoir une variété d'applications. Une requête LINQ peut être écrite en C # ou en Visual Basic de manière pratique.
Microsoft propose des outils pour ces deux langages, à savoir C # et Visual Basic au moyen de Visual Studio. Nos exemples sont tous compilés et écrits dans Visual Studio 2010. Cependant, l'édition de Visual Basic 2013 est également disponible. Il s'agit de la dernière version et présente de nombreuses similitudes avec Visual Studio 2012.
Obtenir Visual Studio 2010 installé sur Windows 7
Visual Studio peut être installé à partir d'un support d'installation tel qu'un DVD. Les informations d'identification de l'administrateur sont requises pour installer correctement Visual Basic 2010 sur votre système. Il est vital de déconnecter toutes les clés USB amovibles du système avant l'installation, sinon l'installation peut échouer. Certaines des exigences matérielles essentielles à avoir pour l'installation sont les suivantes.
Exigences matérielles
- 1,6 GHz ou plus
- 1 Go de RAM
- 3 Go (espace disponible sur le disque dur)
- Disque dur 5400 tr / min
- Carte vidéo compatible DirectX 9
- Lecteur de DVD-ROM
Etapes d'installation
Step 1 - D'abord après avoir inséré le DVD avec le package Visual Studio 2010, cliquez sur Install or run program from your media apparaissant dans une fenêtre contextuelle à l'écran.
Step 2- Maintenant configuré pour Visual Studio apparaîtra à l'écran. ChoisirInstall Microsoft Visual Studio 2010.
Step 3- Dès que vous cliquerez, le processus sera lancé et une fenêtre de configuration apparaîtra sur votre écran. Une fois le chargement des composants d'installation qui prendra un certain temps, cliquez surNext pour passer à l'étape suivante.
Step 4 - C'est la dernière étape de l'installation et une page de démarrage apparaîtra dans laquelle il suffit de choisir "J'ai lu et j'accepte les termes de la licence" et cliquez sur Next bouton.
Step 5- Sélectionnez maintenant les fonctionnalités à installer à partir de la page d'options qui apparaît sur votre écran. Vous pouvez soit choisirFull ou Customoption. Si vous disposez de moins d'espace disque que requis indiqué dans les exigences d'espace disque, optez pour Personnalisé.
Step 6- Lorsque vous choisissez l'option Personnalisée, la fenêtre suivante apparaît. Sélectionnez les fonctionnalités que vous souhaitez installer et cliquez surUpdate ou bien passez à l'étape 7. Cependant, il est recommandé de ne pas utiliser l'option personnalisée car à l'avenir, vous pourriez avoir besoin des fonctionnalités que vous avez choisi de ne pas avoir.
Step 7- Bientôt, une fenêtre contextuelle s'affiche et l'installation démarre, ce qui peut prendre un certain temps. N'oubliez pas que c'est pour installer tous les composants.
Step 8- Enfin, vous pourrez afficher un message dans une fenêtre indiquant que l'installation s'est terminée avec succès. Cliquez surFinish.
Écriture d'un programme C # à l'aide de LINQ dans Visual Studio 2010
Démarrez Visual Studio 2010 Ultimate Edition et choisissez Fichier suivi de Nouveau projet dans le menu.
Une nouvelle boîte de dialogue de projet apparaîtra sur votre écran.
Maintenant, choisissez Visual C # comme catégorie sous les modèles installés, puis choisissez le modèle d'application console comme illustré dans la figure ci-dessous.
Donnez un nom à votre projet dans la zone de nom du bas et appuyez sur OK.
Le nouveau projet apparaîtra dans l'Explorateur de solutions dans la partie droite d'une nouvelle boîte de dialogue sur votre écran.
Maintenant, choisissez Program.cs dans l'Explorateur de solutions et vous pouvez afficher le code dans la fenêtre de l'éditeur qui commence par «using System».
Ici, vous pouvez commencer à coder votre programme C # suivant.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace HelloWorld {
class Program {
static void Main(string[] args) {
Console.WriteLine("Hello World")
Console.ReadKey();
}
}
}
Appuyez sur la touche F5 et exécutez votre projet. Il est fortement recommandé de sauvegarder le projet en choisissantFile → Save All avant d'exécuter le projet.
Écriture du programme VB à l'aide de LINQ dans Visual Studio 2010
Démarrez Visual Studio 2010 Ultimate Edition et choisissez Fichier suivi de Nouveau projet dans le menu.
Une nouvelle boîte de dialogue de projet apparaîtra sur votre écran.
Maintenant, choisissez Visual Basic comme catégorie sous les modèles installés et choisissez ensuite le modèle d'application console.
Donnez un nom à votre projet dans la zone de nom du bas et appuyez sur OK.
Vous obtiendrez un écran avec Module1.vb. Commencez à écrire votre code VB ici en utilisant LINQ.
Module Module1
Sub Main()
Console.WriteLine("Hello World")
Console.ReadLine()
End Sub
End Module
Appuyez sur la touche F5 et exécutez votre projet. Il est fortement recommandé de sauvegarder le projet en choisissantFile → Save All avant d'exécuter le projet.
Lorsque le code ci-dessus de C # ou VB est cimpiled et exécuté, il produit le résultat suivant -
Hello World
Un ensemble de méthodes d'extension formant un modèle de requête est connu sous le nom d'opérateurs de requête standard LINQ. En tant que blocs de construction des expressions de requête LINQ, ces opérateurs offrent une gamme de fonctionnalités de requête telles que le filtrage, le tri, la projection, l'agrégation, etc.
Les opérateurs de requête standard LINQ peuvent être classés dans les suivants en fonction de leurs fonctionnalités.
- Opérateurs de filtrage
- Rejoignez les opérateurs
- Opérations de projection
- Opérateurs de tri
- Opérateurs de regroupement
- Conversions
- Concatenation
- Aggregation
- Opérations de quantificateur
- Opérations de partition
- Opérations de génération
- Définir les opérations
- Equality
- Opérateurs d'élément
Opérateurs de filtrage
Le filtrage est une opération visant à restreindre l'ensemble de résultats de telle sorte qu'il ne contienne que des éléments sélectionnés satisfaisant à une condition particulière.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
où | Filtrer les valeurs en fonction d'une fonction de prédicat | où | Où |
OfType | Filtrer les valeurs en fonction de leur capacité à être comme un type spécifié | N'est pas applicable | N'est pas applicable |
Rejoignez les opérateurs
La jointure fait référence à une opération dans laquelle des sources de données avec des relations difficiles à suivre les unes avec les autres de manière directe sont ciblées.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Joindre | L'opérateur joint deux séquences sur la base de clés correspondantes | rejoindre… dans… sur… égal… | De x dans…, y dans… où xa = ya |
Rejoindre un groupe | Joindre deux séquences et regrouper les éléments correspondants | rejoindre… dans… sur… égal… dans… | Rejoindre le groupe… Dans… Le… |
Opérations de projection
La projection est une opération dans laquelle un objet est transformé en une forme totalement nouvelle avec seulement des propriétés spécifiques.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Sélectionner | L'opérateur projette des valeurs sur la base d'une fonction de transformation | sélectionner | Sélectionner |
SélectionnezBeaucoup | L'opérateur projette les séquences de valeurs basées sur une fonction de transformation et les aplatit en une seule séquence | Utiliser plusieurs clauses from | Utiliser plusieurs clauses From |
Opérateurs de tri
Une opération de tri permet d'ordonner les éléments d'une séquence sur la base d'un ou plusieurs attributs.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Commandé par | L'opérateur trie les valeurs dans un ordre croissant | commandé par | Commandé par |
OrderByDescending | L'opérateur trie les valeurs dans un ordre décroissant | ordre par ... décroissant | Trier par ... décroissant |
Puis par | Exécute un tri secondaire dans un ordre croissant | commandé par …, … | Commandé par …, … |
ThenByDescendant | Exécute un tri secondaire dans un ordre décroissant | orderby…,… décroissant | Trier par…,… Décroissant |
Inverser | Effectue une inversion de l'ordre des éléments dans une collection | N'est pas applicable | N'est pas applicable |
Opérateurs de regroupement
Les opérateurs placent les données dans certains groupes en fonction d'un attribut partagé commun.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Par groupe | Organisez une séquence d'éléments en groupes et retournez-les sous la forme d'une collection IEnumerable de type IGrouping <key, element> | grouper… par -ou- grouper… par… en… | Regrouper… par… en… |
Pour rechercher | Exécuter une opération de regroupement dans laquelle une séquence de paires de clés est renvoyée | N'est pas applicable | N'est pas applicable |
Les conversions
Les opérateurs changent le type d'objets d'entrée et sont utilisés dans une large gamme d'applications.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
AsEnumerable | Renvoie l'entrée tapée comme IEnumerable <T> | N'est pas applicable | N'est pas applicable |
AsQueryable | Un IEnumerable (générique) est converti en un IQueryable (générique) | N'est pas applicable | N'est pas applicable |
Jeter | Effectue le cast des éléments d'une collection vers un type spécifié | Utilisez une variable de plage explicitement typée. Par exemple: à partir de la chaîne str dans les mots | De… En tant que… |
OfType | Filtre les valeurs en fonction de leur, en fonction de leur capacité à être converties en un type particulier | N'est pas applicable | N'est pas applicable |
ToArray | Force l'exécution de la requête et effectue la conversion d'une collection en tableau | N'est pas applicable | N'est pas applicable |
ToDictionary | Sur la base d'une fonction de sélection de clé, définissez les éléments dans un Dictionary <TKey, TValue> et force l'exécution d'une requête LINQ | N'est pas applicable | N'est pas applicable |
Lister | Force l'exécution d'une requête en convertissant une collection en List <T> | N'est pas applicable | N'est pas applicable |
Pour rechercher | Force l'exécution d'une requête et place des éléments dans un Lookup <TKey, TElement> sur la base d'une fonction de sélection de clé | N'est pas applicable | N'est pas applicable |
Enchaînement
Effectue la concaténation de deux séquences et est assez similaire à l'opérateur de l'Union en termes de son fonctionnement, sauf que cela ne supprime pas les doublons.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Concat | Deux séquences sont concaténées pour la formation d'une seule séquence. | N'est pas applicable | N'est pas applicable |
Agrégation
Effectue tout type d'agrégation souhaitée et permet de créer des agrégations personnalisées dans LINQ.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Agrégat | Fonctionne sur les valeurs d'une collection pour effectuer une opération d'agrégation personnalisée | N'est pas applicable | N'est pas applicable |
Moyenne | La valeur moyenne d'une collection de valeurs est calculée | N'est pas applicable | Agréger… en… en moyenne () |
Compter | Compte les éléments satisfaisant une fonction de prédicat dans la collection | N'est pas applicable | Agréger… dans… en nombre () |
LonCount | Compte les éléments satisfaisant une fonction de prédicat dans une vaste collection | N'est pas applicable | Agréger… dans… dans LongCount () |
Max | Découvrez la valeur maximale d'une collection | N'est pas applicable | Agréger… In… Into Max () |
Min | Découvrez la valeur minimale existante dans une collection | N'est pas applicable | Agréger… dans… en min () |
Somme | Découvrez la somme des valeurs d'une collection | N'est pas applicable | Agréger… dans… en somme () |
Opérations de quantificateur
Ces opérateurs renvoient une valeur booléenne, c'est-à-dire True ou False lorsque certains ou tous les éléments d'une séquence satisfont à une condition spécifique.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Tout | Renvoie une valeur 'True' si tous les éléments d'une séquence satisfont à une condition de prédicat | N'est pas applicable | Agréger… dans… dans tout (…) |
Tout | Détermine en recherchant une séquence que si un élément de la même chose satisfait à une condition spécifiée | N'est pas applicable | Agréger… dans… en n'importe quel () |
Contient | Renvoie une valeur 'True' si trouve qu'un élément spécifique est présent dans une séquence si la séquence ne contient pas cet élément spécifique, la valeur 'false' est renvoyée | N'est pas applicable | N'est pas applicable |
Opérateurs de partition
Divisez une séquence d'entrée en deux sections distinctes sans réorganiser les éléments de la séquence, puis en renvoyer l'une d'entre elles.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Sauter | Ignore un nombre spécifié d'éléments dans une séquence et renvoie les autres | N'est pas applicable | Sauter |
SkipWhile | Identique à celui de Skip à la seule exception que le nombre d'éléments à ignorer est spécifié par une condition booléenne | N'est pas applicable | Passer pendant |
Prendre | Prenez un nombre spécifié d'éléments d'une séquence et ignorez les autres | N'est pas applicable | Prendre |
TakeWhile | Identique à celui de Take sauf le fait que le nombre d'éléments à prendre est spécifié par une condition booléenne | N'est pas applicable | Prendre pendant |
Opérations de génération
Une nouvelle séquence de valeurs est créée par les opérateurs générationnels.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
DefaultIfEmpty | Lorsqu'il est appliqué à une séquence vide, génère un élément par défaut dans une séquence | N'est pas applicable | N'est pas applicable |
Vide | Renvoie une séquence vide de valeurs et est l'opérateur générationnel le plus simple | N'est pas applicable | N'est pas applicable |
Intervalle | Génère une collection ayant une séquence d'entiers ou de nombres | N'est pas applicable | N'est pas applicable |
Répéter | Génère une séquence contenant des valeurs répétées d'une longueur spécifique | N'est pas applicable | N'est pas applicable |
Définir les opérations
Il existe quatre opérateurs pour les opérations d'ensemble, chacun produisant un résultat basé sur différents critères.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
Distinct | Résultats une liste de valeurs uniques d'une collection en filtrant les données en double le cas échéant | N'est pas applicable | Distinct |
Sauf | Compare les valeurs de deux collections et renvoie celles d'une collection qui ne sont pas dans l'autre collection | N'est pas applicable | N'est pas applicable |
Couper | Renvoie l'ensemble des valeurs trouvées pour être identiques dans deux collections séparées | N'est pas applicable | N'est pas applicable |
syndicat | Combine le contenu de deux collections différentes en une seule liste sans aucun contenu en double | N'est pas applicable | N'est pas applicable |
Égalité
Compare deux phrases (énumérables) et détermine si elles correspondent exactement ou non.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
SequenceEqual | Résultats une valeur booléenne si deux séquences sont identiques l'une à l'autre | N'est pas applicable | N'est pas applicable |
Opérateurs d'élément
À l'exception de DefaultIfEmpty, les huit autres opérateurs d'élément de requête standard renvoient un seul élément d'une collection.
Afficher des exemples
Opérateur | La description | Syntaxe d'expression de requête C # | Syntaxe d'expression de requête VB |
---|---|---|---|
ElementAt | Renvoie un élément présent dans un index spécifique d'une collection | N'est pas applicable | N'est pas applicable |
ElementAtOrDefault | Identique à ElementAt, à l'exception du fait qu'il renvoie également une valeur par défaut au cas où l'index spécifique serait hors de portée | N'est pas applicable | N'est pas applicable |
Première | Récupère le premier élément d'une collection ou le premier élément satisfaisant une condition spécifique | N'est pas applicable | N'est pas applicable |
FirstOrDefault | Identique à First sauf le fait qu'il renvoie également une valeur par défaut au cas où il n'y aurait pas de tels éléments | N'est pas applicable | N'est pas applicable |
Dernier | Récupère le dernier élément présent dans une collection ou le dernier élément satisfaisant une condition spécifique | N'est pas applicable | N'est pas applicable |
LastOrDefault | Identique à Last sauf le fait qu'il renvoie également une valeur par défaut au cas où il n'y aurait aucun élément de ce type | N'est pas applicable | N'est pas applicable |
Célibataire | Renvoie l'élément unique d'une collection ou l'élément isolé qui satisfait à une certaine condition | N'est pas applicable | N'est pas applicable |
SingleOrDefault | Identique à Single sauf qu'il renvoie également une valeur par défaut s'il n'y a pas d'existence d'un tel élément isolé | N'est pas applicable | N'est pas applicable |
DefaultIfEmpty | Renvoie une valeur par défaut si la collection ou la liste est vide ou nulle | N'est pas applicable | N'est pas applicable |
LINQ to SQL offre une infrastructure (run-time) pour la gestion des données relationnelles en tant qu'objets. Il s'agit d'un composant de la version 3.5 du .NET Framework et effectue efficacement la traduction des requêtes intégrées au langage du modèle objet en SQL. Ces requêtes sont ensuite envoyées à la base de données à des fins d'exécution. Après avoir obtenu les résultats de la base de données, LINQ to SQL les convertit à nouveau en objets.
Introduction de LINQ To SQL
Pour la plupart des développeurs ASP.NET, LINQ to SQL (également connu sous le nom de DLINQ) est une partie électrisante de la requête intégrée au langage car cela permet d'interroger des données dans la base de données du serveur SQL à l'aide d'expressions LINQ habituelles. Il permet également de mettre à jour, supprimer et insérer des données, mais le seul inconvénient dont il souffre est sa limitation à la base de données du serveur SQL. Cependant, LINQ to SQL présente de nombreux avantages par rapport à ADO.NET, comme une complexité réduite, quelques lignes de codage et bien d'autres.
Vous trouverez ci-dessous un diagramme montrant l'architecture d'exécution de LINQ to SQL.
Comment utiliser LINQ to SQL?
Step 1- Faire une nouvelle «connexion de données» avec le serveur de base de données. Afficher & arrar; Explorateur de serveurs & arrar; Connexions de données & arrar; Ajouter une connexion
Step 2 - Ajouter un fichier de classe LINQ To SQL
Step 3 - Sélectionnez des tables dans la base de données et faites-les glisser dans le nouveau fichier de classe LINQ to SQL.
Step 4 - Ajout de tables au fichier de classe.
Interroger avec LINQ to SQL
Les règles d'exécution d'une requête avec LINQ to SQL sont similaires à celles d'une requête LINQ standard, c'est-à-dire que la requête est exécutée différée ou immédiate. Il existe différents composants qui jouent un rôle dans l'exécution d'une requête avec LINQ to SQL et ce sont les suivants.
LINQ to SQL API - demande l'exécution de la requête au nom d'une application et l'envoie à LINQ to SQL Provider.
LINQ to SQL Provider - convertit la requête en Transact SQL (T-SQL) et envoie la nouvelle requête au fournisseur ADO pour exécution.
ADO Provider - Après l'exécution de la requête, envoyez les résultats sous la forme d'un DataReader à LINQ to SQL Provider qui à son tour le convertit en une forme d'objet utilisateur.
Il est à noter qu'avant d'exécuter une requête LINQ to SQL, il est vital de se connecter à la source de données via la classe DataContext.
Insérer, mettre à jour et supprimer à l'aide de LINQ To SQL
Ajouter OU Insérer
C#
using System;
using System.Linq;
namespace LINQtoSQL {
class LinqToSQLCRUD {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
LinqToSQLDataContext db = new LinqToSQLDataContext(connectString);
//Create new Employee
Employee newEmployee = new Employee();
newEmployee.Name = "Michael";
newEmployee.Email = "[email protected]";
newEmployee.ContactNo = "343434343";
newEmployee.DepartmentId = 3;
newEmployee.Address = "Michael - USA";
//Add new Employee to database
db.Employees.InsertOnSubmit(newEmployee);
//Save changes to Database.
db.SubmitChanges();
//Get new Inserted Employee
Employee insertedEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("Michael"));
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}, Address = {4}",
insertedEmployee.EmployeeId, insertedEmployee.Name, insertedEmployee.Email,
insertedEmployee.ContactNo, insertedEmployee.Address);
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Module Module1
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim db As New LinqToSQLDataContext(connectString)
Dim newEmployee As New Employee()
newEmployee.Name = "Michael"
newEmployee.Email = "[email protected]"
newEmployee.ContactNo = "343434343"
newEmployee.DepartmentId = 3
newEmployee.Address = "Michael - USA"
db.Employees.InsertOnSubmit(newEmployee)
db.SubmitChanges()
Dim insertedEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("Michael"))
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3},
Address = {4}", insertedEmployee.EmployeeId, insertedEmployee.Name,
insertedEmployee.Email, insertedEmployee.ContactNo, insertedEmployee.Address)
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Emplyee ID = 4, Name = Michael, Email = [email protected], ContactNo =
343434343, Address = Michael - USA
Press any key to continue.
Mettre à jour
C#
using System;
using System.Linq;
namespace LINQtoSQL {
class LinqToSQLCRUD {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
LinqToSQLDataContext db = new LinqToSQLDataContext(connectString);
//Get Employee for update
Employee employee = db.Employees.FirstOrDefault(e =>e.Name.Equals("Michael"));
employee.Name = "George Michael";
employee.Email = "[email protected]";
employee.ContactNo = "99999999";
employee.DepartmentId = 2;
employee.Address = "Michael George - UK";
//Save changes to Database.
db.SubmitChanges();
//Get Updated Employee
Employee updatedEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("George Michael"));
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}, Address = {4}",
updatedEmployee.EmployeeId, updatedEmployee.Name, updatedEmployee.Email,
updatedEmployee.ContactNo, updatedEmployee.Address);
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Module Module1
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim db As New LinqToSQLDataContext(connectString)
Dim employee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("Michael"))
employee.Name = "George Michael"
employee.Email = "[email protected]"
employee.ContactNo = "99999999"
employee.DepartmentId = 2
employee.Address = "Michael George - UK"
db.SubmitChanges()
Dim updatedEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("George Michael"))
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3},
Address = {4}", updatedEmployee.EmployeeId, updatedEmployee.Name,
updatedEmployee.Email, updatedEmployee.ContactNo, updatedEmployee.Address)
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
Lorsque le code ci-dessus de C # ou Vb est compilé et exécuté, il produit le résultat suivant -
Emplyee ID = 4, Name = George Michael, Email = [email protected], ContactNo =
999999999, Address = Michael George - UK
Press any key to continue.
Effacer
C#
using System;
using System.Linq;
namespace LINQtoSQL {
class LinqToSQLCRUD {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
LinqToSQLDataContext db = newLinqToSQLDataContext(connectString);
//Get Employee to Delete
Employee deleteEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("George Michael"));
//Delete Employee
db.Employees.DeleteOnSubmit(deleteEmployee);
//Save changes to Database.
db.SubmitChanges();
//Get All Employee from Database
var employeeList = db.Employees;
foreach (Employee employee in employeeList) {
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}",
employee.EmployeeId, employee.Name, employee.Email, employee.ContactNo);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Module Module1
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim db As New LinqToSQLDataContext(connectString)
Dim deleteEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("George Michael"))
db.Employees.DeleteOnSubmit(deleteEmployee)
db.SubmitChanges()
Dim employeeList = db.Employees
For Each employee As Employee In employeeList
Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}",
employee.EmployeeId, employee.Name, employee.Email, employee.ContactNo)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Emplyee ID = 1, Name = William, Email = [email protected], ContactNo = 999999999
Emplyee ID = 2, Name = Miley, Email = [email protected], ContactNo = 999999999
Emplyee ID = 3, Name = Benjamin, Email = [email protected], ContactNo =
Press any key to continue.
LINQ to Objects offre l'utilisation de toute requête LINQ prenant en charge IEnumerable <T> pour accéder aux collections de données en mémoire sans avoir besoin du fournisseur LINQ (API) comme dans le cas de LINQ to SQL ou LINQ to XML.
Introduction de LINQ aux objets
Les requêtes dans LINQ to Objects renvoient des variables de type généralement IEnumerable <T> uniquement. En bref, LINQ to Objects offre une nouvelle approche des collections car auparavant, il était vital d'écrire un codage long (pourchaque boucles de grande complexité) pour récupérer les données d'une collection qui est maintenant remplacée par l'écriture de code déclaratif qui décrit clairement les données souhaitées qui est nécessaire pour récupérer.
LINQ to Objects présente également de nombreux avantages par rapport aux boucles foreach traditionnelles, comme une plus grande lisibilité, un filtrage puissant, une capacité de regroupement, une commande améliorée avec un codage d'application minimal. Ces requêtes LINQ sont également de nature plus compacte et sont portables vers toutes les autres sources de données sans aucune modification ou avec juste une petite modification.
Voici un exemple simple de LINQ to Objects -
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace LINQtoObjects {
class Program {
static void Main(string[] args) {
string[] tools = { "Tablesaw", "Bandsaw", "Planer", "Jointer", "Drill", "Sander" };
var list = from t in tools select t;
StringBuilder sb = new StringBuilder();
foreach (string s in list) {
sb.Append(s + Environment.NewLine);
}
Console.WriteLine(sb.ToString(), "Tools");
Console.ReadLine();
}
}
}
Dans l'exemple, un tableau de chaînes (outils) est utilisé comme collection d'objets à interroger à l'aide de LINQ to Objects.
Objects query is:
var list = from t in tools select t;
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
Tablesaw
Bandsaw
Planer
Jointer
Drill
Sander
Interrogation dans les collections de mémoire à l'aide de LINQ to Objects
C #
using System;
using System.Collections.Generic;
using System.Linq;
namespace LINQtoObjects {
class Department {
public int DepartmentId { get; set; }
public string Name { get; set; }
}
class LinqToObjects {
static void Main(string[] args) {
List<Department> departments = new List<Department>();
departments.Add(new Department { DepartmentId = 1, Name = "Account" });
departments.Add(new Department { DepartmentId = 2, Name = "Sales" });
departments.Add(new Department { DepartmentId = 3, Name = "Marketing" });
var departmentList = from d in departments
select d;
foreach (var dept in departmentList) {
Console.WriteLine("Department Id = {0} , Department Name = {1}",
dept.DepartmentId, dept.Name);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Module Module1
Sub Main(ByVal args As String())
Dim account As New Department With {.Name = "Account", .DepartmentId = 1}
Dim sales As New Department With {.Name = "Sales", .DepartmentId = 2}
Dim marketing As New Department With {.Name = "Marketing", .DepartmentId = 3}
Dim departments As New System.Collections.Generic.List(Of Department)(New Department() {account, sales, marketing})
Dim departmentList = From d In departments
For Each dept In departmentList
Console.WriteLine("Department Id = {0} , Department Name = {1}", dept.DepartmentId, dept.Name)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
Class Department
Public Property Name As String
Public Property DepartmentId As Integer
End Class
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Department Id = 1, Department Name = Account
Department Id = 2, Department Name = Sales
Department Id = 3, Department Name = Marketing
Press any key to continue.
Un jeu de données offre une représentation de données extrêmement utile en mémoire et est utilisé pour une large gamme d'applications basées sur les données. LINQ to Dataset en tant que l'une des technologies de LINQ to ADO.NET facilite l'exécution de requêtes sur les données d'un Dataset sans tracas et améliore la productivité.
Introduction de LINQ To Dataset
LINQ to Dataset a simplifié la tâche des requêtes pour les développeurs. Ils n'ont pas besoin d'écrire des requêtes dans un langage de requête spécifique au lieu de cela, la même chose peut être écrite en langage de programmation. LINQ to Dataset est également utilisable pour interroger où les données sont consolidées à partir de plusieurs sources de données. Cela ne nécessite pas non plus de fournisseur LINQ, tout comme LINQ to SQL et LINQ to XML pour accéder aux données à partir de collections en mémoire.
Vous trouverez ci-dessous un exemple simple de requête LINQ to Dataset dans laquelle une source de données est d'abord obtenue, puis l'ensemble de données est rempli de deux tables de données. Une relation est établie entre les deux tables et une requête LINQ est créée sur les deux tables au moyen d'une clause de jointure. Enfin, la boucle foreach permet d'afficher les résultats souhaités.
C #
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace LINQtoDataset {
class Program {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
string sqlSelect = "SELECT * FROM Department;" + "SELECT * FROM Employee;";
// Create the data adapter to retrieve data from the database
SqlDataAdapter da = new SqlDataAdapter(sqlSelect, connectString);
// Create table mappings
da.TableMappings.Add("Table", "Department");
da.TableMappings.Add("Table1", "Employee");
// Create and fill the DataSet
DataSet ds = new DataSet();
da.Fill(ds);
DataRelation dr = ds.Relations.Add("FK_Employee_Department",
ds.Tables["Department"].Columns["DepartmentId"],
ds.Tables["Employee"].Columns["DepartmentId"]);
DataTable department = ds.Tables["Department"];
DataTable employee = ds.Tables["Employee"];
var query = from d in department.AsEnumerable()
join e in employee.AsEnumerable()
on d.Field<int>("DepartmentId") equals
e.Field<int>("DepartmentId")
select new {
EmployeeId = e.Field<int>("EmployeeId"),
Name = e.Field<string>("Name"),
DepartmentId = d.Field<int>("DepartmentId"),
DepartmentName = d.Field<string>("Name")
};
foreach (var q in query) {
Console.WriteLine("Employee Id = {0} , Name = {1} , Department Name = {2}",
q.EmployeeId, q.Name, q.DepartmentName);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Data.SqlClient
Imports System.Linq
Module LinqToDataSet
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim sqlSelect As String = "SELECT * FROM Department;" + "SELECT * FROM Employee;"
Dim sqlCnn As SqlConnection = New SqlConnection(connectString)
sqlCnn.Open()
Dim da As New SqlDataAdapter
da.SelectCommand = New SqlCommand(sqlSelect, sqlCnn)
da.TableMappings.Add("Table", "Department")
da.TableMappings.Add("Table1", "Employee")
Dim ds As New DataSet()
da.Fill(ds)
Dim dr As DataRelation = ds.Relations.Add("FK_Employee_Department", ds.Tables("Department").Columns("DepartmentId"), ds.Tables("Employee").Columns("DepartmentId"))
Dim department As DataTable = ds.Tables("Department")
Dim employee As DataTable = ds.Tables("Employee")
Dim query = From d In department.AsEnumerable()
Join e In employee.AsEnumerable() On d.Field(Of Integer)("DepartmentId") Equals
e.Field(Of Integer)("DepartmentId")
Select New Person With { _
.EmployeeId = e.Field(Of Integer)("EmployeeId"),
.EmployeeName = e.Field(Of String)("Name"),
.DepartmentId = d.Field(Of Integer)("DepartmentId"),
.DepartmentName = d.Field(Of String)("Name")
}
For Each e In query
Console.WriteLine("Employee Id = {0} , Name = {1} , Department Name = {2}", e.EmployeeId, e.EmployeeName, e.DepartmentName)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
Class Person
Public Property EmployeeId As Integer
Public Property EmployeeName As String
Public Property DepartmentId As Integer
Public Property DepartmentName As String
End Class
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Employee Id = 1, Name = William, Department Name = Account
Employee Id = 2, Name = Benjamin, Department Name = Account
Employee Id = 3, Name = Miley, Department Name = Sales
Press any key to continue.
Interroger un ensemble de données à l'aide de LinQ vers un ensemble de données
Avant de commencer à interroger un Dataset à l'aide de LINQ to Dataset, il est vital de charger des données dans un Dataset et cela se fait soit à l'aide de la classe DataAdapter, soit par LINQ to SQL. La formulation de requêtes à l'aide de LINQ to Dataset est assez similaire à la formulation de requêtes à l'aide de LINQ avec d'autres sources de données compatibles LINQ.
Requête à table unique
Dans la requête de table unique suivante, toutes les commandes en ligne sont collectées à partir de SalesOrderHeaderTtable, puis l'ID de commande, la date de commande ainsi que le numéro de commande sont affichés en sortie.
C#
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace LinqToDataset {
class SingleTable {
static void Main(string[] args) {
string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();
string sqlSelect = "SELECT * FROM Department;";
// Create the data adapter to retrieve data from the database
SqlDataAdapter da = new SqlDataAdapter(sqlSelect, connectString);
// Create table mappings
da.TableMappings.Add("Table", "Department");
// Create and fill the DataSet
DataSet ds = new DataSet();
da.Fill(ds);
DataTable department = ds.Tables["Department"];
var query = from d in department.AsEnumerable()
select new {
DepartmentId = d.Field<int>("DepartmentId"),
DepartmentName = d.Field<string>("Name")
};
foreach (var q in query) {
Console.WriteLine("Department Id = {0} , Name = {1}",
q.DepartmentId, q.DepartmentName);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Data.SqlClient
Imports System.Linq
Module LinqToDataSet
Sub Main()
Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()
Dim sqlSelect As String = "SELECT * FROM Department;"
Dim sqlCnn As SqlConnection = New SqlConnection(connectString)
sqlCnn.Open()
Dim da As New SqlDataAdapter
da.SelectCommand = New SqlCommand(sqlSelect, sqlCnn)
da.TableMappings.Add("Table", "Department")
Dim ds As New DataSet()
da.Fill(ds)
Dim department As DataTable = ds.Tables("Department")
Dim query = From d In department.AsEnumerable()
Select New DepartmentDetail With {
.DepartmentId = d.Field(Of Integer)("DepartmentId"),
.DepartmentName = d.Field(Of String)("Name")
}
For Each e In query
Console.WriteLine("Department Id = {0} , Name = {1}", e.DepartmentId, e.DepartmentName)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
Public Class DepartmentDetail
Public Property DepartmentId As Integer
Public Property DepartmentName As String
End Class
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Department Id = 1, Name = Account
Department Id = 2, Name = Sales
Department Id = 3, Name = Pre-Sales
Department Id = 4, Name = Marketing
Press any key to continue.
LINQ to XML offre un accès facile à toutes les fonctionnalités de LINQ telles que les opérateurs de requête standard, l'interface de programmation, etc. et bien plus à dire.
Introduction de LINQ to XML
Lors de l'utilisation de LINQ to XML, le chargement de documents XML en mémoire est facile et plus facile est l'interrogation et la modification de document. Il est également possible de sauvegarder sur disque les documents XML existants en mémoire et de les sérialiser. Il élimine le besoin pour un développeur d'apprendre le langage de requête XML qui est quelque peu complexe.
LINQ to XML a sa puissance dans l'espace de noms System.Xml.Linq. Cela a toutes les 19 classes nécessaires pour travailler avec XML. Ces classes sont les suivantes.
- XAttribute
- XCData
- XComment
- XContainer
- XDeclaration
- XDocument
- XDocumentType
- XElement
- XName
- XNamespace
- XNode
- XNodeDocumentOrderComparer
- XNodeEqualityComparer
- XObject
- XObjectChange
- XObjectChangeEventArgs
- XObjectEventHandler
- XProcessingInstruction
- XText
Lire un fichier XML à l'aide de LINQ
C #
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;
namespace LINQtoXML {
class ExampleOfXML {
static void Main(string[] args) {
string myXML = @"<Departments>
<Department>Account</Department>
<Department>Sales</Department>
<Department>Pre-Sales</Department>
<Department>Marketing</Department>
</Departments>";
XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(myXML);
var result = xdoc.Element("Departments").Descendants();
foreach (XElement item in result) {
Console.WriteLine("Department Name - " + item.Value);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq
Module Module1
Sub Main(ByVal args As String())
Dim myXML As String = "<Departments>" & vbCr & vbLf &
"<Department>Account</Department>" & vbCr & vbLf &
"<Department>Sales</Department>" & vbCr & vbLf &
"<Department>Pre-Sales</Department>" & vbCr & vbLf &
"<Department>Marketing</Department>" & vbCr & vbLf &
"</Departments>"
Dim xdoc As New XDocument()
xdoc = XDocument.Parse(myXML)
Dim result = xdoc.Element("Departments").Descendants()
For Each item As XElement In result
Console.WriteLine("Department Name - " + item.Value)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Department Name - Account
Department Name - Sales
Department Name - Pre-Sales
Department Name - Marketing
Press any key to continue.
Ajouter un nouveau nœud
C #
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;
namespace LINQtoXML {
class ExampleOfXML {
static void Main(string[] args) {
string myXML = @"<Departments>
<Department>Account</Department>
<Department>Sales</Department>
<Department>Pre-Sales</Department>
<Department>Marketing</Department>
</Departments>";
XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(myXML);
//Add new Element
xdoc.Element("Departments").Add(new XElement("Department", "Finance"));
//Add new Element at First
xdoc.Element("Departments").AddFirst(new XElement("Department", "Support"));
var result = xdoc.Element("Departments").Descendants();
foreach (XElement item in result) {
Console.WriteLine("Department Name - " + item.Value);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq
Module Module1
Sub Main(ByVal args As String())
Dim myXML As String = "<Departments>" & vbCr & vbLf &
"<Department>Account</Department>" & vbCr & vbLf &
"<Department>Sales</Department>" & vbCr & vbLf &
"<Department>Pre-Sales</Department>" & vbCr & vbLf &
"<Department>Marketing</Department>" & vbCr & vbLf &
"</Departments>"
Dim xdoc As New XDocument()
xdoc = XDocument.Parse(myXML)
xdoc.Element("Departments").Add(New XElement("Department", "Finance"))
xdoc.Element("Departments").AddFirst(New XElement("Department", "Support"))
Dim result = xdoc.Element("Departments").Descendants()
For Each item As XElement In result
Console.WriteLine("Department Name - " + item.Value)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Department Name - Support
Department Name - Account
Department Name - Sales
Department Name - Pre-Sales
Department Name - Marketing
Department Name - Finance
Press any key to continue.
Suppression d'un nœud particulier
C #
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;
namespace LINQtoXML {
class ExampleOfXML {
static void Main(string[] args) {
string myXML = @"<Departments>
<Department>Support</Department>
<Department>Account</Department>
<Department>Sales</Department>
<Department>Pre-Sales</Department>
<Department>Marketing</Department>
<Department>Finance</Department>
</Departments>";
XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(myXML);
//Remove Sales Department
xdoc.Descendants().Where(s =>s.Value == "Sales").Remove();
var result = xdoc.Element("Departments").Descendants();
foreach (XElement item in result) {
Console.WriteLine("Department Name - " + item.Value);
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
VB
Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq
Module Module1
Sub Main(args As String())
Dim myXML As String = "<Departments>" & vbCr & vbLf &
"<Department>Support</Department>" & vbCr & vbLf &
"<Department>Account</Department>" & vbCr & vbLf &
"<Department>Sales</Department>" & vbCr & vbLf &
"<Department>Pre-Sales</Department>" & vbCr & vbLf &
"<Department>Marketing</Department>" & vbCr & vbLf &
"<Department>Finance</Department>" & vbCr & vbLf &
"</Departments>"
Dim xdoc As New XDocument()
xdoc = XDocument.Parse(myXML)
xdoc.Descendants().Where(Function(s) s.Value = "Sales").Remove()
Dim result = xdoc.Element("Departments").Descendants()
For Each item As XElement In result
Console.WriteLine("Department Name - " + item.Value)
Next
Console.WriteLine(vbLf & "Press any key to continue.")
Console.ReadKey()
End Sub
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
Department Name - Support
Department Name - Account
Department Name - Pre-Sales
Department Name - Marketing
Department Name - Finance
Press any key to continue.
Faisant partie de ADO.NET Entity Framework, LINQ to Entities est plus flexible que LINQ to SQL, mais n'est pas très populaire en raison de sa complexité et de son manque de fonctionnalités clés. Cependant, il n'a pas les limitations de LINQ to SQL qui autorise la requête de données uniquement dans la base de données du serveur SQL car LINQ to Entities facilite la requête de données dans un grand nombre de fournisseurs de données comme Oracle, MySQL, etc.
De plus, il bénéficie d'un support majeur d'ASP.Net dans le sens où les utilisateurs peuvent utiliser un contrôle de source de données pour exécuter une requête via LINQ to Entities et facilite la liaison des résultats sans avoir besoin de codage supplémentaire.
LINQ to Entities est devenu pour ces avantages le mécanisme standard pour l'utilisation de LINQ sur les bases de données de nos jours. Il est également possible avec LINQ to Entities de modifier les détails des données interrogées et de valider facilement une mise à jour par lots. Le fait le plus intriguant à propos de LINQ to Entities est qu'il a la même syntaxe que celle de SQL et même le même groupe d'opérateurs de requête standard tels que Join, Select, OrderBy, etc.
Processus de création et d'exécution de requêtes LINQ to Entities
Construction d'un ObjectQuery instance hors d'un ObjectContext (Connexion d'entité)
Composer une requête en C # ou en Visual Basic (VB) à l'aide de l'instance nouvellement construite
Conversion d'opérateurs de requête standard de LINQ ainsi que d'expressions LINQ en arborescences de commandes
Exécution de la requête en transmettant directement les exceptions rencontrées au client
Renvoyer au client tous les résultats de la requête
ObjectContext est ici la classe principale qui permet l'interaction avec Entity Data Modelou en d'autres termes agit comme un pont qui connecte LINQ à la base de données. Les arborescences de commandes sont ici une représentation de requête avec compatibilité avec le framework Entity.
L'Entity Framework, d'autre part, est en fait Object Relational Mapperabrégé généralement en ORM par les développeurs qui fait la génération d'objets métier ainsi que d'entités selon les tables de la base de données et facilite diverses opérations de base telles que la création, la mise à jour, la suppression et la lecture. L'illustration suivante montre la structure d'entité et ses composants.
Exemple d'ADD, UPDATE et DELETE à l'aide de LINQ avec Entity Model
Ajoutez d'abord le modèle d'entité en suivant les étapes ci-dessous.
Step 1- Cliquez avec le bouton droit sur le projet et cliquez sur Ajouter un nouvel élément pour ouvrir la fenêtre ci-dessous. Sélectionnez ADO.NET Entity Data Model et spécifiez le nom et cliquez sur Ajouter.
Step 2 - Sélectionnez Generate from database.
Step 3 - Choisissez Connexion à la base de données dans le menu déroulant.
Step 4 - Sélectionnez toutes les tables.
Maintenant, écrivez le code suivant.
using DataAccess;
using System;
using System.Linq;
namespace LINQTOSQLConsoleApp {
public class LinqToEntityModel {
static void Main(string[] args) {
using (LinqToSQLDBEntities context = new LinqToSQLDBEntities()) {
//Get the List of Departments from Database
var departmentList = from d in context.Departments
select d;
foreach (var dept in departmentList) {
Console.WriteLine("Department Id = {0} , Department Name = {1}",
dept.DepartmentId, dept.Name);
}
//Add new Department
DataAccess.Department department = new DataAccess.Department();
department.Name = "Support";
context.Departments.Add(department);
context.SaveChanges();
Console.WriteLine("Department Name = Support is inserted in Database");
//Update existing Department
DataAccess.Department updateDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 1);
updateDepartment.Name = "Account updated";
context.SaveChanges();
Console.WriteLine("Department Name = Account is updated in Database");
//Delete existing Department
DataAccess.Department deleteDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 3);
context.Departments.Remove(deleteDepartment);
context.SaveChanges();
Console.WriteLine("Department Name = Pre-Sales is deleted in Database");
//Get the Updated List of Departments from Database
departmentList = from d in context.Departments
select d;
foreach (var dept in departmentList) {
Console.WriteLine("Department Id = {0} , Department Name = {1}",
dept.DepartmentId, dept.Name);
}
}
Console.WriteLine("\nPress any key to continue.");
Console.ReadKey();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
Le terme «expression lambda» a dérivé son nom du calcul «lambda» qui à son tour est une notation mathématique appliquée pour définir des fonctions. Les expressions Lambda en tant que partie exécutable d'une équation LINQ traduisent la logique d'une manière au moment de l'exécution afin qu'elle puisse la transmettre facilement à la source de données. Cependant, les expressions lambda ne se limitent pas uniquement à rechercher des applications dans LINQ.
Ces expressions sont exprimées par la syntaxe suivante -
(Input parameters) ⇒ Expression or statement block
Voici un exemple d'expression lambda -
y ⇒ y * y
L'expression ci-dessus spécifie un paramètre nommé y et cette valeur de y est au carré. Cependant, il n'est pas possible d'exécuter une expression lambda sous cette forme. Un exemple d'expression lambda en C # est présenté ci-dessous.
C #
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace lambdaexample {
class Program {
delegate int del(int i);
static void Main(string[] args) {
del myDelegate = y ⇒ y * y;
int j = myDelegate(5);
Console.WriteLine(j);
Console.ReadLine();
}
}
}
VB
Module Module1
Private Delegate Function del(ByVal i As Integer) As Integer
Sub Main(ByVal args As String())
Dim myDelegate As del = Function(y) y * y
Dim j As Integer = myDelegate(5)
Console.WriteLine(j)
Console.ReadLine()
End Sub
End Module
Lorsque le code ci-dessus de C # ou VB est compilé et exécuté, il produit le résultat suivant -
25
Expression Lambda
Comme l'expression dans la syntaxe de l'expression lambda présentée ci-dessus est sur le côté droit, ceux-ci sont également connus sous le nom d'expression lambda.
Lambdas asynchrones
L'expression lambda créée en incorporant un traitement asynchrone à l'aide du mot clé async est connue sous le nom de lambdas asynchrones. Voici un exemple de lambda asynchrone.
Func<Task<string>> getWordAsync = async()⇒ “hello”;
Lambda dans les opérateurs de requête standard
Une expression lambda dans un opérateur de requête est évaluée par le même à la demande et fonctionne en permanence sur chacun des éléments de la séquence d'entrée et non sur la séquence entière. Les développeurs sont autorisés par l'expression Lambda à introduire leur propre logique dans les opérateurs de requête standard. Dans l'exemple ci-dessous, le développeur a utilisé l'opérateur 'Where' pour récupérer les valeurs impaires d'une liste donnée en utilisant une expression lambda.
C #
//Get the average of the odd Fibonacci numbers in the series...
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace lambdaexample {
class Program {
static void Main(string[] args) {
int[] fibNum = { 1, 1, 2, 3, 5, 8, 13, 21, 34 };
double averageValue = fibNum.Where(num ⇒ num % 2 == 1).Average();
Console.WriteLine(averageValue);
Console.ReadLine();
}
}
}
VB
Module Module1
Sub Main()
Dim fibNum As Integer() = {1, 1, 2, 3, 5, 8, 13, 21, 34}
Dim averageValue As Double = fibNum.Where(Function(num) num Mod 2 = 1).Average()
Console.WriteLine(averageValue)
Console.ReadLine()
End Sub
End Module
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
7.33333333333333
Inférence de type dans Lambda
En C #, l'inférence de type est utilisée de manière pratique dans diverses situations et cela aussi sans spécifier les types explicitement. Cependant, dans le cas d'une expression lambda, l'inférence de type ne fonctionnera que lorsque chaque type a été spécifié car le compilateur doit être satisfait. Prenons l'exemple suivant.
delegate int Transformer (int i);
Ici, le compilateur utilise l'inférence de type pour tirer parti du fait que x est un entier et cela se fait en examinant le type de paramètre du Transformer.
Portée variable dans l'expression Lambda
Il existe certaines règles lors de l'utilisation de la portée de variable dans une expression lambda, comme les variables initiées dans une expression lambda ne sont pas censées être visibles dans une méthode externe. Il existe également une règle selon laquelle une variable capturée ne doit pas être garbage collection à moins que le délégué qui la référence ne devienne éligible pour l'acte de garbage collection. De plus, il existe une règle qui interdit qu'une instruction return dans une expression lambda provoque le retour d'une méthode englobante.
Voici un exemple pour illustrer la portée de la variable dans une expression lambda.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace lambdaexample {
class Program {
delegate bool D();
delegate bool D2(int i);
class Test {
D del;
D2 del2;
public void TestMethod(int input) {
int j = 0;
// Initialize the delegates with lambda expressions.
// Note access to 2 outer variables.
// del will be invoked within this method.
del = () ⇒ { j = 10; return j > input; };
// del2 will be invoked after TestMethod goes out of scope.
del2 = (x) ⇒ { return x == j; };
// Demonstrate value of j:
// The delegate has not been invoked yet.
Console.WriteLine("j = {0}", j); // Invoke the delegate.
bool boolResult = del();
Console.WriteLine("j = {0}. b = {1}", j, boolResult);
}
static void Main() {
Test test = new Test();
test.TestMethod(5);
// Prove that del2 still has a copy of
// local variable j from TestMethod.
bool result = test.del2(10);
Console.WriteLine(result);
Console.ReadKey();
}
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
j = 0
j = 10. b = True
True
Arbre d'expression
Les expressions Lambda sont utilisées dans Expression Treeconstruction en profondeur. Un arbre d'expression donne du code dans une structure de données ressemblant à un arbre dans lequel chaque nœud est lui-même une expression comme un appel de méthode ou peut être une opération binaire comme x <y. Vous trouverez ci-dessous un exemple d'utilisation de l'expression lambda pour construire une arborescence d'expression.
Déclaration Lambda
Il y a aussi statement lambdasconsistant en deux ou trois instructions, mais ne sont pas utilisés dans la construction d'arbres d'expression. Une instruction return doit être écrite dans une instruction lambda.
Syntaxe de l'instruction lambda
(params)⇒ {statements}
Exemple d'instruction lambda
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Linq.Expressions;
namespace lambdaexample {
class Program {
static void Main(string[] args) {
int[] source = new[] { 3, 8, 4, 6, 1, 7, 9, 2, 4, 8 };
foreach (int i in source.Where(x ⇒
{
if (x <= 3)
return true;
else if (x >= 7)
return true;
return false;
}
))
Console.WriteLine(i);
Console.ReadLine();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
3
8
1
7
9
2
8
Les lambdas sont utilisés comme arguments dans les requêtes LINQ basées sur des méthodes et ne sont jamais autorisés à avoir une place sur le côté gauche des opérateurs comme is ou astout comme les méthodes anonymes. Bien que les expressions Lambda soient très similaires aux méthodes anonymes, elles ne sont pas du tout limitées à être utilisées en tant que délégués uniquement.
Points à retenir lors de l'utilisation d'expressions lambda
Une expression lambda peut renvoyer une valeur et peut avoir des paramètres.
Les paramètres peuvent être définis de multiples façons avec une expression lambda.
S'il y a une seule instruction dans une expression lambda, il n'est pas nécessaire de placer des accolades alors que s'il y a plusieurs instructions, les accolades ainsi que la valeur de retour sont essentielles à écrire.
Avec les expressions lambda, il est possible d'accéder aux variables présentes en dehors du bloc d'expression lambda par une fonctionnalité appelée fermeture. L'utilisation de la fermeture doit être faite avec prudence pour éviter tout problème.
Il est impossible d'exécuter un code non sécurisé dans une expression lambda.
Les expressions Lambda ne sont pas destinées à être utilisées sur le côté gauche de l'opérateur.
En tant qu'ensemble d'extensions .NET Framework, LINQ est le mécanisme préféré pour l'accès aux données par les développeurs ASP.NET. ASP.NET 3.5 dispose d'un contrôle LINQDataSource outil intégré qui permet d'utiliser facilement LINQ dans ASP.NET. ASP.NET utilise le contrôle mentionné ci-dessus comme source de données. Les projets réels englobent principalement des sites Web ou des applications Windows.Pour mieux comprendre le concept de LINQ avec ASP.NET, commençons par créer un site Web ASP.NET qui utilise les fonctionnalités de LINQ.
Pour cela, il est essentiel d'installer Visual Studio et .NET Framework sur votre système. Une fois que vous avez ouvert Visual Studio, accédez à Fichier → Nouveau → Site Web. Une fenêtre contextuelle s'ouvre comme indiqué dans la figure ci-dessous.
Maintenant, sous les modèles sur le côté gauche, il y aura deux options de langue pour créer le site Web. ChoisirVisual C# et sélectionnez ASP.NET Empty Web Site.
Sélectionnez le dossier dans lequel vous souhaitez enregistrer le nouveau site Web sur votre système. Puis appuyezOK etc Solution Explorerapparaît sur votre écran contenant tous les fichiers Web. Cliquez avec le bouton droit sur Default.aspx dans l'Explorateur de solutions et choisissez Afficher dans le navigateur pour afficher le site Web ASP.NET par défaut dans le navigateur. Bientôt, votre nouveau site Web ASP.NET s'ouvrira dans le navigateur Web, comme illustré dans la capture d'écran suivante.
.aspx est en fait la principale extension de fichier utilisée dans les sites Web ASP.NET. Visual Studio par défaut crée toutes les pages nécessaires pour un site Web de base commeHome page et About Uspage où vous pouvez placer votre contenu de manière pratique. Le code du site Web est généré automatiquement ici et peut également être consulté.
Contrôle LINQDataSource
Il est possible de UPDATE, INSERT et DELETEdonnées dans les pages du site Web ASP.NET à l'aide du contrôle LINQDataSource. Il n'est absolument pas nécessaire de spécifier des commandes SQL car le contrôle LINQDataSource utilise des commandes créées dynamiquement pour de telles opérations.
Le contrôle permet à un utilisateur d'utiliser LINQ dans une page Web ASP.NET de manière pratique en définissant une propriété dans le texte de balisage. LINQDataSource est très similaire à celui des contrôles commeSqlDataSource aussi bien que ObjectDataSourcecar il peut être utilisé pour lier d'autres contrôles ASP.NET présents sur une page à une source de données. Donc, nous devons avoir undatabase pour expliquer les différentes fonctions appelées par le contrôle LINQDataSource.
Avant de commencer l'explication de l'utilisation du contrôle dans le formulaire de page Web ASP.NET, il est essentiel d'ouvrir la boîte à outils Microsoft Visual Studio et de faire glisser et déposer le contrôle LINQDataSource sur la page .aspx du site Web ASP.NET comme illustré ci-dessous.
L'étape suivante consiste à configurer LINQDataSource en sélectionnant toutes les colonnes de l'enregistrement d'employé.
Ajoutez maintenant un contrôle GridView à la page .aspx et configurez-le comme indiqué dans la figure ci-dessous. Le contrôle GridView est puissant et offre la flexibilité de travailler avec les données. Peu de temps après avoir configuré le contrôle, il apparaîtra dans le navigateur.
Le codage qui peut être visualisé maintenant sur votre écran pour la page .aspx sera -
<!DOCTYPE html>
<html>
<head runat = "server">
<title></title>
</head>
<body>
<form id = "form1" runat = "server">
<div>
<asp:GridView ID = "GridView1" runat = "server" AutoGenerateColumns = "False"
DataKeyNames = "ContactID" DataSourceID = "LINQDataSource1">
<Columns>
<asp:BoundField DataField = "ContactID" HeaderText = "ContactID"
InsertVisible = "False" ReadOnly="True" SortExpression = "ContactID" />
<asp:CheckBoxField DataField = "NameStyle" HeaderText = "NameStyle"
SortExpression = "NameStyle" />
<asp:BoundField DataField = "Title" HeaderText = "Title" SortExpression = "Title" />
<asp:BoundField DataField = "FirstName" HeaderText = "FirstName"
SortExpression="FirstName" />
<asp:BoundField DataField = "MiddleName" HeaderText = "MiddleName"
SortExpression = "MiddleName" />
<asp:BoundField DataField = "LastName" HeaderText = "LastName"
SortExpression = "LastName" />
<asp:BoundField DataField = "Suffix" HeaderText = "Suffix"
SortExpression = "Suffix" />
<asp:BoundField DataField = "EmailAddress" HeaderText = "EmailAddress"
SortExpression = "EmailAddress" />
</Columns>
</asp:GridView>
<br />
</div>
<asp:LINQDataSource ID = "LINQDataSource1" runat = "server"
ContextTypeName = "LINQWebApp1.AdventureWorksDataContext" EntityTypeName = ""
TableName = "Contacts">
</asp:LINQDataSource>
</form>
</body>
</html>
Ici, il convient de noter qu'il est vital de définir la propriété ContextTypeName sur celle de la classe représentant la base de données. Par exemple, ici, il est donné comme LINQWebApp1.AdventureWorksDataContext car cette action établira la connexion nécessaire entre LINQDataSource et la base de données.
INSERT, UPDATE et DELETE des données dans la page ASP.NET à l'aide de LINQ
Après avoir suivi rigoureusement toutes les étapes ci-dessus, choisissez le LINQDataSource Tasks du LINQDataSource Control et choisissez les trois cases pour activer l'insertion, activer la mise à jour et activer la suppression de la même chose, comme indiqué dans la capture d'écran suivante.
Bientôt, le balisage déclaratif s'affichera sur votre écran comme le suivant.
<asp:LINQDataSource
ContextTypeName = "LINQWebApp1.AdventureWorksDataContext"
TableName = "Contacts"
EnableUpdate = "true"
EnableInsert = "true"
EnableDelete = "true"
ID = "LINQDataSource1"
runat = "server">
</asp:LINQDataSource>
Désormais, étant donné qu'il existe plusieurs lignes et colonnes, il est préférable d'ajouter un autre contrôle sur votre formulaire .aspx nommé en tant que contrôle Vue détaillée ou Contrôle principal sous le contrôle Vue grille pour afficher uniquement les détails d'une ligne sélectionnée de la grille. Choisissez les tâches de vue détaillée dans le contrôle Vue détaillée et cochez les cases comme indiqué ci-dessous.
Maintenant, enregistrez simplement les modifications et appuyez sur Ctrl + F5 pour afficher la page dans votre navigateur où il est désormais possible de supprimer, mettre à jour, insérer n'importe quel enregistrement sur le contrôle de vue de détail.