我有一个数据集表,我想按列MOID
对其进行分组,然后在该组中我想选择最大值为radi
的行。
有人能告诉我如何通过LINQ to dataset做到这一点吗?
答案 0 :(得分:6)
虽然Barry发布的解决方案应该有效(有一些修复),但它不是最佳的:您不需要对集合进行排序以查找具有字段最大值的项目。我写了一个WithMax
扩展方法,它返回具有指定函数的最大值的项:
public static T WithMax<T, TValue>(this IEnumerable<T> source, Func<T, TValue> selector)
{
var max = default(TValue);
var withMax = default(T);
bool first = true;
var comparer = Comparer<TValue>.Default;
foreach (var item in source)
{
var value = selector(item);
int compare = comparer.Compare(value, max);
if (compare > 0 || first)
{
max = value;
withMax = item;
}
first = false;
}
return withMax;
}
它只对集合进行一次迭代,这比仅仅为了得到第一个项目要快得多。
然后您可以按如下方式使用它
var query =
from row in table.AsEnumerable()
group row by row.Field<int>("MOID") into g
select g.WithMax(r => r.Field<int>("radi"));
答案 1 :(得分:2)
这是未经测试的,但我认为这样的事情应该有效:
var qry = from m in [YourDataSource]
group p by m.MOID into grp
select grp.OrderByDescending(a => a.RADI).First();
答案 2 :(得分:0)
这适用于一个查询!
public static T WithMax<T, TValue>(this IEnumerable<T> source, Func<T, TValue> keySelector)
{
return source.OrderByDescending(keySelector).FirstOrDefault();
}