Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Abonnements

Comment effectuer plusieurs fonctions de grouping en une seule requête LINQ ?

Derrière la magie d’Entity Framework se cache la réalité du SQL. Je persiste et je signe, si vous ne connaissez pas le SQL, il sera très compliqué d’écrire des requêtes L2E optimales.

J’ai trouvé une bonne illustrations avec les fonctions de grouping.

Comment récupérer la dernière date de commande et le nombre de commandes ?

En SQL, on peut écrire la requête suivante :

SELECT COUNT(1), MAX(OrderDate)

FROM Orders

Mais comment faire la même chose en LINQ ?

Bien sûr, on pourrait utiliser deux requêtes mais il y a un point très important à prendre en compte avant de faire ça : la performance. En effet, le coût pour récupérer le count ou le max ou le count et le max est le même :

image_thumb[1]

Cela signifie que, même en ignorant le coût des deux connections à la base, avoir deux requêtes pour récupérer le nombre de commande et la date de la dernière commande est deux fois plus important que de récupérer ces informations en une seule requête !

Si l’on pense SQL, la fonction COUNT et MAX sont des fonctions de grouping.

On obtient le même plan d’exécution en utilisant un group by sur une constante :

SELECT COUNT(1), MAX(OrderDate)

FROM

(

SELECT OrderDate, 1 AS G

FROM Orders

) O

GROUP BY O.G

image_thumb[7]

Et ça on peut l’écrire en LINQ :

from o in context.Orders
group o by 1 into g
select new { Count = g.Count(), MaxOrderDate = g.Max(o => o.OrderDate) };
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 :

Publié mardi 14 juin 2011 21:53 par Matthieu MEZIL

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- Intégration Yammer et SharePoint Online (Office 365), étape 1 … par Le blog de Patrick [MVP SharePoint] le 06-12-2013, 17:37

- [Dynamics CRM] Ajouter les dossiers de CRM au dossier Favoris d’Outlook par Christine Dubois le 06-10-2013, 15:50

- Visual Studio 2013 par Etienne Margraff le 06-04-2013, 10:26

- Configurer la collation SQL Server pour SharePoint par Blog de Jérémy Jeanson le 06-03-2013, 19:48

- Etendre le Team Web Access de TFS 2012 – Step 1: Création du plugin par Philippe Didiergeorges Aka Philess le 06-03-2013, 07:30

- Livre Blanc : Développer des applications NUI par Fathi Bellahcene le 06-01-2013, 11:35

- [Dynamics CRM 2011] Copier une vue d'entité par Christine Dubois le 05-29-2013, 13:20

- [Conf’SharePoint 2013] Mes présentations… par Le blog de Patrick [MVP SharePoint] le 05-28-2013, 09:04

- [wpdev] Storage bug in MediaLibrary.SavePicture par Kévin Gosse le 05-26-2013, 19:08

- VMMap en mode instrumentation sur système 64bit : attention à la plateforme cible du build .NET par CoqBlog le 05-25-2013, 22:25