LINQ的分组聚合技术

文/Jonathan Allen  译/张海龙  出处/InfoQ

很大程度上来讲,LINQ的工作方式很像SQL。查询源定义、join、select和where子句都是相当标准的,而Group/By/Into子句则正是我们这里要仔细说明的。SQL总是返回矩阵式数据集,与它不同的是,LINQ具备了返回层次化数据的能力,这也给它自己带来了更多新的挑战。
举一个例子,将客户按照所属country和city进行分组查询,在SQL中,可能会通过在客户端手动分组或者执行1+N+(N*M)次查询来实现,一个查询用来获取所有的国家,一个查询用来获取每个国家的所有城市,然后再逐个查询出每个国家的每个城市下所有的客户列表。

而在LINQ中,它可以通过一个带有一系列子查询的查询语句一次性完成,当然,这也增加了查询的复杂度。Mitsu演示如下:

var q =
    from c in db.Customers
    group c by c.Country into g
    select new {
        g.Key,
        Count = g.Count(),
        SubGroups = from c in g
                  group c by c.City into g2
                  select g2};
为说明LINQ框架的灵活性,Mitsu将它简化到了仅一行:

var result = customers.GroupByMany(c => c.Country, c => c.City);
Mitsu用一种能适用于任何LINQ查询的方式实现了它。你可以在他的博客上查看源码以及关于它是如何工作的解释文章。

友情提示:此文并不表示本站肯定持有相同观点,转载请注明出处。
 您可能对 [Linq] 的这些文章也感兴趣:

Jimmy Nilsson谈LINQ to SQL  LINQ体验(18)——LINQ to SQL语句之视图和继承支持
LINQ体验(5)——LINQ语句之Select/Distinct和Count/Sum/Min/Max/Avg  LINQ to SQL异步查询
LINQ查询关键字使用之from,group,select,into,where(C#)  LINQ体验(17)——LINQ to SQL语句之动态查询
使用LINQ TO SQL实现单表数据在DataGridView批编辑  LINQ to SQL 辅助工具
扩展LINQ to SQL以支持批量删除  LINQ体验(4)——LINQ简介和LINQ语句之Where
LINQ可视化查询编辑器: VLinq  LINQ and Pipeline Pattern
LINQ基本操作  LINQ体验(16)——LINQ to SQL语句之DataContext
PLINQ改名为Parallel Extensions发布  LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL
LINQ的分组聚合技术  Linq to sql--使用自定义的SQL语句
LINQ体验(11)——LINQ to SQL语句之Null语义和String/DateTime方法  在Linq to Sql中使用记录的时间戳进行检测管理并发更新时的冲突
拼吾爱变形金刚