我想使用LINQ对DataTable中的数据进行分组(列:userid,chargetag,charge)。
内容可能如下所示:
userid chargetag charge
-----------------------------
user1 tag3 100
user2 tag3 100
user3 tag5 250
我需要这样的结果:
chargetag count sum
-------------------------
tag3 2 200
tag5 1 250
这是我到目前为止所做的:
var groupedData = from b in dataTable.AsEnumerable()
group b by b.Field<string>("chargetag") into g
let count = g.Count()
select new
{
ChargeTag = g.Key,
Count = count,
};
我可以提取出收据标签的名称和号码。 我如何更改LINQ查询以访问费用总和呢?
提前致谢: - )
此致 凯文
答案 0 :(得分:36)
这很简单 - 只需在组中使用Sum
扩展方法。
var groupedData = from b in dataTable.AsEnumerable()
group b by b.Field<string>("chargetag") into g
select new
{
ChargeTag = g.Key,
Count = g.Count(),
ChargeSum = g.Sum(x => x.Field<int>("charge"))
};
(我在这里删除了let
条款,因为它并没有真正为你买任何东西。)
现在可能效率低下;它可能最终分组两次以执行两次聚合操作。如果您真的想要,可以修复,就像查询延续一样:
var groupedData = from b in dataTable.AsEnumerable()
group b by b.Field<string>("chargetag") into g
select new
{
ChargeTag = g.Key,
List = g.ToList(),
} into g
select new
{
g.ChargeTag,
Count = g.List.Count,
ChargeSum = g.List.Sum(x => x.Field<int>("charge"))
};
或者改为使用let
子句:
var groupedData = from b in dataTable.AsEnumerable()
group b by b.Field<string>("chargetag") into g
let list = g.ToList()
select new
{
ChargeTag = g.Key,
Count = list.Count,
ChargeSum = list.Sum(x => x.Field<int>("charge"))
};