LINQ构建交叉表
最近碰到客户的一个需求。使用交叉表来显示客户数据。也就是以同时以行头和列头交叉形式显示数据内容。同时要求即使有些列没有数据,也需要显示该列内容,并设置默认值。
说明: “交叉表”对象是一个网格,用来根据指定的条件返回值。数据显示在压缩行和列中。这种格式易于比较数据并辨别其趋势。它由三个元素组成:
- 行
- 列
- 摘要字段
以下是SQL表的数据结构:
学生 |
课程 |
分数 |
王佳佳 |
语文 |
90 |
李晓华 |
语文 |
39 |
王佳佳 |
英语 |
42 |
李建军 |
英语 |
33 |
吴培华 |
数学 |
20 |
这是用于显示的表结构:
学生/课程 |
语文 |
英语 |
数学 |
物理 |
化学 |
地理 |
王佳佳 |
90 |
90 |
90 |
无 |
64 |
无 |
李晓华 |
无 |
69 |
90 |
90 |
无 |
无 |
李建军 |
78 |
83 |
无 |
64 |
无 |
无 |
吴培华 |
93 |
80- |
无 |
无 |
无 |
无 |
“交叉表”中的行沿水平方向延伸(从一侧到另一侧)。在上面的示例中,“课程” 是一行。
“交叉表”中的列沿垂直方向延伸(上下)。在上面的示例中,“学生” 是一列。
汇总字段位于行和列的交叉处。每个交叉处的值代表对既满足行条件又满足列条件的记录的汇总(求和、计数等)。在上面的示例中,“王佳佳”和“英语”交叉处的值是90,表示王佳佳的英语分数。
使用LINQ来筛选数据:
static void Main(string[] args)
{
DataTable dt = new DataTable();
dt.Columns.Add("学生");
dt.Columns.Add("课程");
dt.Columns.Add("分数", typeof(int));
dt.Rows.Add("谢一帆", "语文", );
dt.Rows.Add("谢一帆", "英语", );
dt.Rows.Add("谢一帆", "数学", );
dt.Rows.Add("王佳佳", "英语", );
dt.Rows.Add("王佳佳", "数学", );
dt.Rows.Add("王佳佳", "化学", );
dt.Rows.Add("吴灵敏", "英语", );
dt.Rows.Add("胡虎珏", "化学", ); var groupedData = from b in dt.AsEnumerable()
group b by b.Field<string>("学生") into g
let list = g.ToList()
select new
{
学生 = g.Key,
语文 = list.Where(x => x.Field<string>("课程").Equals("语文")).Count().Equals() ? "无" : list.Find(x => x.Field<string>("课程").Equals("语文")).Field<int?>("分数").ToString(),
英语 = list.Where(x => x.Field<string>("课程").Equals("英语")).Count().Equals() ? "无" : list.Find(x => x.Field<string>("课程").Equals("英语")).Field<int?>("分数").ToString(),
数学 = list.Where(x => x.Field<string>("课程").Equals("数学")).Count().Equals() ? "无" : list.Find(x => x.Field<string>("课程").Equals("数学")).Field<int?>("分数").ToString(),
物理 = list.Where(x => x.Field<string>("课程").Equals("物理")).Count().Equals() ? "无" : list.Find(x => x.Field<string>("课程").Equals("物理")).Field<int?>("分数").ToString(),
化学 = list.Where(x => x.Field<string>("课程").Equals("化学")).Count().Equals() ? "无" : list.Find(x => x.Field<string>("课程").Equals("化学")).Field<int?>("分数").ToString(),
地理 = list.Where(x => x.Field<string>("课程").Equals("地理")).Count().Equals() ? "无" : list.Find(x => x.Field<string>("课程").Equals("地理")).Field<int?>("分数").ToString(),
}
; groupedData.ToList().ForEach(q => Console.WriteLine(q.学生 + " " + q.语文 + " " + q.英语 + " " + q.数学 + " " + q.地理));
Console.ReadLine();
}
Select内的语句嫌丑陋,还求高手指导予以修正。
打印结果:
LINQ构建交叉表的更多相关文章
- Quick BI的宝藏工具——交叉表
对于普通的表格展示数据,相信大家都非常熟悉了,今天给大家介绍的是BI领域的分析利器-交叉表,这个在BI分析场景中使用占比最多的分析利器.通过交叉表对数据的承载和管理,用户可以一目了然地分析出各种场景指 ...
- DevExpress XtraPivotGrid 交叉表 重复显示问题
转自:http://www.cnblogs.com/xiayan/archive/2011/11/04/2236389.html 最近发现xtrareport 的PivotGrid实现交叉表非常的简单 ...
- LINQ 联查多表数据并封装到ViewModel的实现
LINQ 联查多表数据并封装到ViewModel的实现 public List<MyTask> GetPagedTaskList(int pageIndex, int pageSize, ...
- Qlikview 处理交叉表数据
数据来源于crossTable的时候,如何将数据做明细显示. 如图示交叉表数据 使用表格向导,选择交叉表按钮, 结果达到目的. 相关脚本. Month, 表示将要新加的字段的列明,Orders 为明细 ...
- SQL交叉表
之前做货品横向展示时,有看到评论说用到交叉表. 公司最近需要给订单表做一个数据汇总的功能,同事给到一个参考SQL select * from (select COUNT(1) as 已锁定 from ...
- FastReport的交叉表实际使用的一个例子
计算发行-->定义份数月表(打开)出现 PosFraisPaysInput选择时间段后,点击“打印”.这个设计表格,就是交叉表. 交叉表的特点是:数据库是一条一条并列的但是出来的结果却是:横向是 ...
- mysql 行列动态转换(列联表,交叉表)
mysql 行列动态转换(列联表,交叉表) (1)动态,适用于列不确定情况 create table table_name( id int primary key, col1 char(2), col ...
- mysql 交叉表
交叉表,但在MySQL中却没有这个功能,但网上看到有不少朋友想找出一个解决方法,特发贴集思广义.http://topic.csdn.net/u/20090530/23/0b782674-4b0b-4c ...
- XtraReport交叉表隐藏列标题及自定义排序
1.隐藏列标题 用DevExpress PivotGrid report 做报表的时候,将字段拖放到报表中后,ColumnArea和DataArea会显示两个标题字段,如下图: 选中交叉表,设置以下属 ...
随机推荐
- NOIP2009普及组细胞分裂(数论)——yhx
题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家.现在,他正在为一个细胞实 验做准备工作:培养细胞样本. Hanks 博士手里现在有 N 种细胞,编号从 1~N,一个 ...
- codeforces 711B B. Chris and Magic Square(水题)
题目链接: B. Chris and Magic Square 题意: 问在那个空位子填哪个数可以使行列对角线的和相等,就先找一行或者一列算出那个数,再验证是否可行就好; AC代码: #include ...
- UESTC 898 方老师和缘分 --二分图匹配+强连通分量
这题原来以为是某种匹配问题,后来好像说是强连通的问题. 做法:建图,每个方老师和它想要的缘分之间连一条有向边,然后,在给出的初始匹配中反向建边,即如果第i个方老师现在找到的是缘分u,则建边u-> ...
- ssm中使用hibernate-validator验证BO
目前比较流行的验证做法:前端jquery-form-validate + 后端hibernate-validate 在pom中添加相关jar: <!-- use hibernate-valida ...
- [反编译U3D]Decompile Unity Resources
工具说明 反编译unity project资源文件,包括ios,android,pc等平台资源,仅供学习使用! 以下工具任选其一,未有特殊说明是可以同时提取unity3.x,unity4.x,unit ...
- Tomcat 和 Resin 比较,哪个更适合你?
先简单介绍下Resin.Resin是CAUCHO公司的产品,是一个非常流行的application server,对servlet和JSP提供了良好的支持,性能也比较优良,resin自身采用JAVA语 ...
- GitHub入门之二 参与一个项目编写
接上文:大多数时候我们也需要把别人的代码进行整合和修改,而不是简单的修改,这时就需要对一个项目进行修改. 注意,本系列文章主要说明在github网站上的操作,更多高级操作请使用git控制台 一.for ...
- Android SQLite (三 ) 全面详解(一)
官网 SQLite是一款轻型的数据库,是关系型数据库(RDBMS)管理系统,它包含在一个相对小的C库中.目前在很多嵌入式产品中使用了它,它占用资源非常 的低,在嵌入式设备中,可能只需要几百K的内存就够 ...
- emberjs创建类
创建一个Person类Person = Ember.Object.extend({ say: function(thing) { alert(thing); } }); 创建一个Person对象也就是 ...
- 细说git merge & git rebase
git merge和git rebase两个都是用来合并两个分支用的,在使用过程中,这两个概念容易混淆. 在此,对这两个git技巧的用法进行详细描述,希望能帮助一些热爱git的朋友. -------- ...