Linq - Sum()

VS 2005:

 

Func<DataRow, decimal> filter = delegate(DataRow row)
                                                  {
                                                      if (row["dgvColumnItemId"].ToString() == itemId)
                                                          return (decimal)row["dgvColumnQty"];
                                                      return 0;
                                                  };

decimal totalQty = Enumerable.Sum<DataRow>(tripGlobal.curUserRows, filter);

or

 

decimal totalQty = Enumerable.Sum<DataRow>(tripGlobal.curUserRows, delegate(DataRow row)
                                                  {
                                                      if (row["dgvColumnItemId"].ToString() == itemId)
                                                          return (decimal)row["dgvColumnQty"];
                                                      return 0;
                                                  });
   

 

如果要查询DataTable.Rows的结果,视乎要把row放到一个list中.然后用list做TSource。

 

VS 2008:

decimal total = dataTable.AsEnumerable().Where(row => row["dgvColumnItemId"].ToString() == itemId).Sum(row => (decimal)row["dgvColumnQty"]);

 

 

decimal totalQty = (from DataRow row in dataTable.Rows
                               where row["dgvColumnItemId"].ToString() == itemId
                               select new
                               {
                                      qty = row["dgvColumnQty"]
                               }).Sum(a => Convert.ToDecimal(a.qty));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值