Linq 多列分组问题

Linq 多列分组问题,是非常常见的需求。下面引用论坛某位坛友提出的问题:

班级         课程   老师
A  高一班     英语   小王
B  高二班     英语   小王
C  高一班     英语   小张

结果:

班级         课程   老师
A  高一班     英语   小王
C  高一班     英语   小张

经过分析可以看出,根据课程和老师进行分组,重复的取第一行的数据。传统的方法可能要写很多代码,而用Lambda或者Linq只需要几行代码就能实现。

完整代码如下:

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            Data[] data = new Data[] 
            { 
                new Data(){班级="高一班", 课程="英语", 老师="小王"},
                new Data(){班级="高二班", 课程="英语", 老师="小王"},
                new Data(){班级="高一班", 课程="英语", 老师="小张"},
                new Data(){班级="高一班", 课程="英语", 老师="小张"},
            };

            //方式1:Lambda
            var resultLambda = data.GroupBy(x => new { 课程 = x.课程, 老师 = x.老师 }).Select(x => x.FirstOrDefault());
            resultLambda.ToList().ForEach(x => Console.WriteLine(string.Join(",", x.班级, x.课程, x.老师)));

            //方式2:Linq
            var resultLinq = from p in data
                             group p by new { p.课程, p.老师 } into g
                             select new
                             {
                                 班级 = g.FirstOrDefault().班级,
                                 课程 = g.Key.课程,
                                 老师 = g.Key.老师,
                             };
            resultLinq.ToList().ForEach(x => Console.WriteLine(string.Join(",", x.班级, x.课程, x.老师)));
        }
    }

    public class Data
    {
        public string 班级 { get; set; }
        public string 课程 { get; set; }
        public string 老师 { get; set; }
    }
}
时间: 2024-10-10 13:25:38

Linq 多列分组问题的相关文章

TSQL--按某字段列分组,在将各组中某列合并成一行

鉴于群里很多同事在问这个问题,我简单写个Demo,希望对初学者有帮助! 无真相,无解说,不解释,直接上Code! --================================================== --示例代码,仅供参考 --按照object_id分组,将同一组的name列的值合并在一起 SELECT OBJECT_NAME(T1.object_id) AS ObjectName , ( SELECT T2.name + ',' FROM sys.all_columns T

extjs_06_grid(列锁定&列分组)

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>My JSP 'index.jsp' starting pag

比较经典的SQL行转列+分组集联

这是一个比较经典的行转列.用较少的SQL语句,就可以实现行转列.但是此行转列需要根据业务需要,进行二次开发,根据您的需要进行定制和或重写. 下面就简单聊聊这种形式吧 1.建表脚本 CREATE TABLE [dbo].[Table_1]( [a] [int] NOT NULL,--目标列名 [b] [uniqueidentifier] NOT NULL,--目标数据 [c] [nchar](10) NOT NULL--筛选条件) ON [PRIMARY] GO ALTER TABLE [dbo]

linq中的分组和排序

一.分组  group 组内成员 by 分组条件 into 组的信息 class Program { static void Main(string[] args) { string[] name = { "张三","张六","刘大","刘晓","刘大脑袋","王大锤"}; var result = from n in name group n by n[0] into g select

MSSQL&mdash;按照某一列分组后取前N条记录

以前在开发的时候遇到过一个需求,就是要按照某一列进行分组后取前几条数据,今天又有同事碰到了,帮解决了之后顺便写一篇博客记录一下. 首先先建一个基础数据表,代码如下: IF OBJECT_ID(N'Test') IS NOT NULL    BEGIN        DROP TABLE Test    END CREATE TABLE Test(ID bigint IDENTITY(1,1),Name nvarchar(50),Department nvarchar(50)) INSERT IN

LINQ系列:Linq to Object分组操作符

分组是指根据一个特定的值将序列中的值或元素进行分组.LINQ只包含一个分组操作符:GroupBy. GroupBy 1>. 原型定义 public static IQueryable<IGrouping<TKey, TSource>> GroupBy<TSource, TKey>(this IQueryable<TSource> source, Expression<Func<TSource, TKey>> keySelecto

linq to EF分组查询 group by 的使用

第一种:查询表达式语法: IQueryable<EnrollmentDateGroup> data = from student in db.Students group student by student.EnrollmentDate into dateGroup select new EnrollmentDateGroup() { EnrollmentDate = dateGroup.Key, StudentCount = dateGroup.Count() }; return View

linq 中的分组查询

直接看代码: //一个字段分组 var data1 = from a in query group a by a.Name into b select new { Total = b.Sum(c=>c.BrowseRealCount), Id = b.Select(c=>c.Id) }; //多个字段分组,可以使用匿名类方式 var data2 = from a in query group a by new { a.Name, a.Summary } into b select new {

oracle按照指定列分组合计group by rollup()

group by rollup() 按分组合计 select grouping(status),status,owner,object_type,count(*) from dba_objects where owner not in ('SYS','SYSTEM') group by rollup (status,owner,object_type) order by status,owner,object_type; 经典分类查询语句: select object_type,count(*)