C# LINQ对datatable中的数据排序分组统计计算

后台代码:

datatable:dtSource

 //汇总统计
            var q1 = from dt1 in dtSource.AsEnumerable()//查询  
                     orderby dt1.Field<string>("字段1") descending//排序                     
                     where dt1.Field<DateTime>("字段2") >  DateTime.Now  //条件  可用 ==  != 等表达式
                     group dt1 by new { A1 = dt1.Field<string>("字段3") } into m
                     select new
                     {
                         areaName = m.Key.A1,
                         AGENTLICENSE = m.Sum(n1 => Convert.ToDecimal(n1["AGENTLICENSE"])),
                         OUTBOUNDLICENSE = m.Sum(n2 => Convert.ToDecimal(n2["OUTBOUNDLICENSE"])),
                         INBOUNDLICENSE = m.Sum(n3 => Convert.ToDecimal(n3["INBOUNDLICENSE"]))
                     };

//使用得到的结果
            if (q1.ToList().Count > 0)
            {
                q1.ToList().ForEach(q =>

                {

                       a=   q.areaName;

                       b=  q.OUTBOUNDLICENSE;

                       c=  q.INBOUNDLICENSE;
                       d=  q.AGENTLICENSE;

                 }

           }

//转换成datatable,注意dtRtn要有同样的列:

  if (q1.ToList().Count > 0)
        {
            q1.ToList().ForEach(q => dtRtn.Rows.Add(q.a, q.b, q.c, q.d));
        }

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值