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] image_thumb[1]](http://blogs.developpeur.org/blogs/matthieu/image_thumb1_thumb_3664AEDB.png)
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] image_thumb[7]](http://blogs.developpeur.org/blogs/matthieu/image_thumb7_thumb_31524B5F.png)
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 :