gpt4 book ai didi

c# - 跳过可空对象的 ThenBy

转载 作者:太空狗 更新时间:2023-10-29 23:06:44 24 4
gpt4 key购买 nike

我有一个查询应该这样排序:

var list = new List<MonthClosureViewModel>();
var orderedList = list
.OrderByDescending(x => x.Project)
.ThenByDescending(x => x.ChargeLine)
.ThenByDescending(x => x.DomesticSite) //<- x.DomesticSite might be null sometimes
.ThenByDescending(x => x.ChargeSite) //<- x.ChargeSite might be null sometimes
.ThenByDescending(x => x.RateGroup)
.ThenByDescending(x => x.ApprovedHrs)
.ThenByDescending(x => x.NotApprovedHrs);

public class MonthClosureViewModel
{
public Project Project { get; set; }
public ChargeLine ChargeLine { get; set; }
public Site DomesticSite { get; set; }
public Site ChargeSite { get; set; }
public RateGroup RateGroup { get; set; }
public decimal Rate { get; set; }
public decimal ApprovedHrs { get; set; }
public decimal NotApprovedHrs { get; set; }
}

但如果任何对象为空(完全是设计使然),则此查询失败。如果对象为空,如何将空值放在末尾或跳过排序?

添加:正如@LasseV.Karlsen 提到的,我可能还有另一个问题。我真的得到了ArgumentNullException ,但原因不是某些对象背后的原因是null (我在调试器中看到它并错误地认为这是我的问题)。真正的原因是@RaphaëlAlthaus 提到我没有实现 IComparable<>在我的任何类(class)中 MonthClosureViewModel ...

在我完成之后,即使对象是 null,一切都会按预期开始工作

最佳答案

您尝试按复杂属性排序,这是(正如您提到的)真正的问题。

为了使这成为可能,您必须要么

  1. 实现 IComparable<T>在你的类里面

  2. 使用 OrderBy/OrderByDescending 的其他重载,它们也采用 IComparer<TKey>作为参数(msdn 用于 OrderBy 重载)

  3. 在 order by 子句中使用复杂属性的简单属性(带空值检查。在这种情况下,空值检查对于避免空引用异常是必要的):

例如:

.OrderByDescending(x => x.Project == null ? string.Empty : x.Project.Name)

关于c# - 跳过可空对象的 ThenBy,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30394914/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com