C# Linq To DataTable 分组统计 DEMO
DataTable dt = SQLLayer.Get工作量统计(beginDate, endDate);
var querySum = from t in dt.AsEnumerable()
group t by t.Field<string>("库房")
into g
select new
{
_库房 = g.Key,
_品次_入库 = g.Sum(t => t.Field<decimal>("品次_入库")),
_品种_入库 = g.Sum(t => t.Field<decimal>("品种_入库")),
_金额_入库 = g.Sum(t => t.Field<decimal>("金额_入库")),
_品次_出库 = g.Sum(t => t.Field<decimal>("品次_出库")),
_品种_出库 = g.Sum(t => t.Field<decimal>("品种_出库")),
_金额_出库 = g.Sum(t => t.Field<decimal>("金额_出库")),
_品种_现存 = g.Sum(t => t.Field<decimal>("品种_现存")),
_金额_现存 = g.Sum(t => t.Field<decimal>("金额_现存"))
}; DataTable newDt = new DataTable(); DataRow newRow = null;
newDt.Columns.Add("库房", typeof(string));
newDt.Columns.Add("品次_入库", typeof(decimal));
newDt.Columns.Add("品种_入库", typeof(decimal));
newDt.Columns.Add("金额_入库", typeof(decimal));
newDt.Columns.Add("品次_出库", typeof(decimal));
newDt.Columns.Add("品种_出库", typeof(decimal));
newDt.Columns.Add("金额_出库", typeof(decimal));
newDt.Columns.Add("品种_现存", typeof(decimal));
newDt.Columns.Add("金额_现存", typeof(decimal)); foreach (var query in querySum)
{
newRow = newDt.NewRow();
newRow["库房"] = query._库房;
newRow["品次_入库"] = query._品次_入库;
newRow["品种_入库"] = query._品种_入库;
newRow["金额_入库"] = query._金额_入库;
newRow["品次_出库"] = query._品次_出库;
newRow["品种_出库"] = query._品种_出库;
newRow["金额_出库"] = query._金额_出库;
newRow["品种_现存"] = query._品种_现存;
newRow["金额_现存"] = query._金额_现存;
newDt.Rows.Add(newRow); }
private void btnLinqTest__Click(object sender, EventArgs e)
{
DataTable vtblSeqBase = this.DM.bdsSingle._mpDataTable; //1. GroupBy 统计
var query =
from q in vtblSeqBase.AsEnumerable()
group q by q.Field<string>("MachineType") into r
select new
{
_qMachType = r.Key,
_qCount = r.Count()
}; using (DataTable vtblCount = new DataTable())
{
DataRow vNewRow = null;
vtblCount.Columns.Add("MachType", typeof(string));
vtblCount.Columns.Add("Count", typeof(int));
foreach (var vq in query)
{
vNewRow = vtblCount.NewRow();
vNewRow["MachType"] = vq._qMachType;
vNewRow["Count"] = vq._qCount;
vtblCount.Rows.Add(vNewRow);
}
//vtblCount.mmViewForRD();
} //2. Distinct用法 XXXTestOk 2011-07-18
var d = (from DataRow vRow in vtblSeqBase.Rows
select new { _MachType = vRow["MachineType"] }).Distinct();
using (DataTable vtblDistinct = new DataTable())
{
DataRow vNewRow = null;
vtblDistinct.Columns.Add("MachType", typeof(string));
vtblDistinct.Columns.Add("Count", typeof(int));
foreach (var q in d)
{
vNewRow = vtblDistinct.NewRow();
vNewRow["MachType"] = q._MachType;
vtblDistinct.Rows.Add(vNewRow);
}
//vtblDistinct.mmViewForRD();
} //DataTableExtensions.CopyToDataTable //3.
List<int> vListNum = new List<int> { 21, 46, 46, 55, 17, 21, 55, 55 };
IEnumerable<int> vDistNum = vListNum.Distinct();
foreach (int n in vDistNum)
{
//MessageBox.Show("不重复的数值 =" + n.ToString());
} //4. Group By 一个字段
var querySum =
from q in vtblSeqBase.AsEnumerable()
group q by q.Field<string>("MachineType") into g
select new
{
_qMachType = g.Key,
_qSamTotal = g.Sum(q => q.Field<decimal>("SamValue"))
}; using (DataTable vtblSAMTotal = new DataTable())
{
DataRow vNewRow = null;
vtblSAMTotal.Columns.Add("MachType", typeof(string));
vtblSAMTotal.Columns.Add("SAMTotal", typeof(decimal));
foreach (var vq in querySum)
{
vNewRow = vtblSAMTotal.NewRow();
vNewRow["MachType"] = vq._qMachType;
vNewRow["SAMTotal"] = vq._qSamTotal;
vtblSAMTotal.Rows.Add(vNewRow);
}
//vtblSAMTotal.mmViewForRD();
} //5. Group By 多个字段 GBN = Group By NField
var queryGBN =
from q in vtblSeqBase.AsEnumerable()
group q by new {机器代码=q.Field<string>("MachineType"), 工序代码=q.Field<string>("SeqCode") }
into g
select new
{
_qMachType = g.Key,
_qSamTotal = g.Sum(q => q.Field<decimal>("SamValue")),
_qSamAvg = g.Average(q => q.Field<decimal>("SamValue"))
}; using (DataTable vtblSAMTotal = new DataTable())
{
DataRow vNewRow = null;
vtblSAMTotal.Columns.Add("MachType", typeof(string));
vtblSAMTotal.Columns.Add("SeqCode", typeof(string));
vtblSAMTotal.Columns.Add("SAMTotal", typeof(decimal));
vtblSAMTotal.Columns.Add("SAMAvg", typeof(decimal));
foreach (var vq in queryGBN)
{
vNewRow = vtblSAMTotal.NewRow();
vNewRow["MachType"] = vq._qMachType;
vNewRow["SeqCode"] = vq._qMachType;
vNewRow["SAMTotal"] = vq._qSamTotal;
vNewRow["SAMAvg"] = vq._qSamAvg;
vtblSAMTotal.Rows.Add(vNewRow);
}
vtblSAMTotal.mmViewForRD();
}
}
C# Linq To DataTable 分组统计 DEMO的更多相关文章
- 每日学习心得:CustomValidator验证控件验证用户输入的字符长度、Linq 多字段分组统计、ASP.NET后台弹出confirm对话框,然后点击确定,执行一段代码
2013-9-15 1. CustomValidator验证控件验证用户输入的字符长度 在实际的开发中通常会遇到验证用户输入的字符长度的问题,通常的情况下,可以写一个js的脚本或者函数,在ASP ...
- linq 将datatable分组求和在转datatable
DataTable dt = new DataTable(); dt.Columns.Add("CustomerID"); dt.Columns.Add("aa" ...
- DataTable、List使用groupby进行分组和分组统计;List、DataTable查询筛选方法
DataTable分组统计: .用两层循环计算,前提条件是数据已经按分组的列排好序的. DataTable dt = new DataTable(); dt.Columns.AddRange(new ...
- 如何使用linq操作datatable进行分组
使用微软.net的孩子们应该都知道linq吧,要知道linq可是其他高级语言没有的技术,比如php,java等等,但是起初我对linq的认识只是停留在对 list<> 的泛型集合进行操作, ...
- Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等)
Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等) 子查询 描述:查询订单数超过5的顾客信息 查询句法: var 子查询 = from c i ...
- (转)C#用Linq实现DataTable的Group by数据统计
本文转载自:http://www.cnblogs.com/sydeveloper/archive/2013/03/29/2988669.html 1.用两层循环计算,前提条件是数据已经按分组的列排好序 ...
- C# Linq及Lamda表达式实战应用之 GroupBy 分组统计
在项目中做统计图表的时候,需要对查询出来的列表数据进行分组统计,首先想到的是避免频繁去操作数据库可以使用 Linq eg: //例如对列表中的Cu元素进行按年GroupBy分组统计 //包含年份,平均 ...
- Dev用于界面按选中列进行分组统计数据源(实用技巧)
如果有用U8的可以明白这个功能就是模仿他的统计功能.我不过是把他造成通用的与适应于DEV的. (效率为6000条数据分组统计时间为3秒左右分组列过多5秒.1000条以下0.几秒,500条下0.00几秒 ...
- XtraGrid使用心得(折叠式主细档、分组统计)
XtraGrid的关键类就是:GridControl和GridView.GridControl本身不显示数据,数据都是显示在GridView/CardView/XXXXView中.GridContro ...
随机推荐
- JQ限制输入字数,并提示剩余字数
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- myeclipse断点调试
(转) 作为开发者,掌握开发环境下的调试技巧十分有必要.去年就想把关于Eclipse断点调试总结下了.因为对时间的掌控程度仍需极大提高,结果拖到今年才写了此篇博文.关于java调试技术还有非常多.如J ...
- 为一张PCI卡打通经络的过程
一张PCI卡通过“一转二”的转接卡插在主板上,probe调用失败,日志显示读取配置空间的时候发生了奇偶校验错误,可是使用相同的转接卡把它插在另外一台相同机器的主板上时,却运行正常,这就说明不是转接卡的 ...
- 原创 C# 正则表达式 读写 Ini 文件
昨天遇到读ini文件的问题,我知道C#里没有提供相应的类,所有的.net配置都是xml方式存储的. 读取ini文件,很多人直接google一把,然后添加dll引用.介绍的比较详细的,如: C#如何读写 ...
- 【转】cocos2d-x获取系统时间——2013-08-25 10
欢迎转载,本帖地址:http://blog.csdn.net/jinjian2009/article/details/9449585 之前使用过cocos2d-x获取系统时间,毫秒级的 long ge ...
- hdu1047(Java)大数相加
题目大意:输入n组数据,每组数据中又有若干长度不大于100的整数,以0结束每组数据的输入,求每组中数据之和.每两组数据输入之间有一行空格,输出也是如此. Integer Inquiry Time Li ...
- ITopologicalOperator Buffer调用异常的解决方法 .异常来自 HRESULT:0x8004023E
最近在做一个分析功能时,需要循环调用Buffer来对图形创建缓冲区.在开发测试时没问题,但拿到客户实际使用时,出现异常. 后来把出异常的数据拿来测试,发现在调用Buffer时出错.但做为参数传入的图形 ...
- the third assignment of software testing
没有网的日子不好过,Junit4下不下来,先用androidTestCase实现一个. 遇到了几个bug. 首先是除0问题. public void testDivide(){ result=calc ...
- [置顶] c#对于文件的操作
在system.iO:命名空间中提供了两种遍历枚举文件夹的类,Directory 和DirectoryInfo, 他们都有一个方法GetDirectories():来便利枚举文件夹, /// < ...
- eclipse引入jar类包的源代码
为了方便查看源代码,有时候需要对jar类包,引入源代码. 下载源代码 源代码是zip或者rar的压缩包 引入到项目中