首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在数据表中选择列的最小和最大值?

如何在数据表中选择列的最小和最大值?
EN

Stack Overflow用户
提问于 2010-03-14 22:56:44
回答 11查看 219.4K关注 0票数 70

对于下面的datatable列,获取最小和最大值的最快方法是什么?

代码语言:javascript
复制
AccountLevel  
0  
1  
2  
3 
EN

回答 11

Stack Overflow用户

回答已采纳

发布于 2010-03-14 23:58:42

代码语言:javascript
复制
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 MinMax扩展总是比较慢,因为您必须迭代两次。您可能会使用Linq Aggregate,但是其语法不会比现在更漂亮。

票数 56
EN

Stack Overflow用户

发布于 2011-02-07 19:41:33

在datatable上的Easiar方法可以是:

代码语言:javascript
复制
int minLavel = Convert.ToInt32(dt.Compute("min([AccountLevel])", string.Empty));
票数 120
EN

Stack Overflow用户

发布于 2010-03-14 23:16:37

使用LINQ。只要将行集合转换为IEnumerable,它在数据表上就可以很好地工作。

代码语言:javascript
复制
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()作为聚合函数。

票数 16
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2442525

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档