小编典典

如何使用 LINQ 选择具有最小或最大属性值的对象

all

我有一个带有 Nullable DateOfBirth 属性的 Person 对象。有没有一种方法可以使用 LINQ 查询 Person
对象的列表,以查找具有最早/最小 DateOfBirth 值的对象?

这是我开始的:

var firstBornDate = People.Min(p => p.DateOfBirth.GetValueOrDefault(DateTime.MaxValue));

Null DateOfBirth 值设置为 DateTime.MaxValue 以便将它们排除在 Min 考虑之外(假设至少有一个具有指定的 DOB)。

但对我来说所做的只是将 firstBornDate 设置为 DateTime 值。我想得到的是与之匹配的 Person
对象。我是否需要像这样编写第二个查询:

var firstBorn = People.Single(p=> (p.DateOfBirth ?? DateTime.MaxValue) == firstBornDate);

还是有更精简的方法?


阅读 125

收藏
2022-03-11

共1个答案

小编典典

People.Aggregate((curMin, x) => (curMin == null || (x.DateOfBirth ?? DateTime.MaxValue) <
    curMin.DateOfBirth ? x : curMin))
2022-03-11