簡體   English   中英

使用Linq從列數據表或默認值中獲取最大值

[英]Get Max from column datatable or Default Value using Linq

我有一個linq查詢,它查詢數據表列並獲取該字段中的最大值,但遇到一個錯誤,即當數據表中沒有行時,查詢將引發異常。 我想知道是否可以通過放置DefaultIfEmpty來解決此問題,但不知道如何使用它。 這是有效的linq查詢:

Datatable.AsEnumerable().Max(x => Convert.ToInt32(x.Field<string>(Framework.SomeStringField)))

這將獲取該列的最大值,如果可以的話,如何通過使用DefaultifEmpty處理數據表中的行,如何處理返回0

嘗試:

Datatable.AsEnumerable()
         .Select(x => Convert.ToInt32(x.Field<string>(Framework.SomeStringField)))
         .DefaultIfEmpty(0)
         .Max(x => x);

簡單的方法

int max = dataTable.AsEnumerable().Any() ? dataTable.AsEnumerable().Max(x => Convert.ToInt32(x.Field<string>(Framework.SomeStringField))): 0

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM