对于下面的datatable列,获取最小和最大值的最快方法是什么?
AccountLevel
0
1
2
3
发布于 2010-03-14 23:58:42
int minAccountLevel = int.MaxValue;
int maxAccountLevel = int.MinValue;
foreach (DataRow dr in table.Rows)
{
int accountLevel = dr.Field<int>("AccountLevel");
minAccountLevel = Math.Min(minAccountLevel, accountLevel);
maxAccountLevel = Math.Max(maxAccountLevel, accountLevel);
}
是的,这确实是最快的方法。使用Linq Min
和Max
扩展总是比较慢,因为您必须迭代两次。您可能会使用Linq Aggregate
,但是其语法不会比现在更漂亮。
发布于 2011-02-07 19:41:33
在datatable上的Easiar方法可以是:
int minLavel = Convert.ToInt32(dt.Compute("min([AccountLevel])", string.Empty));
发布于 2010-03-14 23:16:37
使用LINQ。只要将行集合转换为IEnumerable,它在数据表上就可以很好地工作。
List<int> levels = AccountTable.AsEnumerable().Select(al => al.Field<int>("AccountLevel")).Distinct().ToList();
int min = levels.Min();
int max = levels.Max();
编辑以修复语法;在DataTables上使用LINQ时很棘手,聚合函数也很有趣。
是的,这可以通过一个查询完成,但是您需要生成一个结果列表,然后在单独的语句中使用.Min()和.Max()作为聚合函数。
https://stackoverflow.com/questions/2442525
复制相似问题