如何在嵌套查询中使用DefaultIfEmpty

时间:2012-06-25 14:54:26

标签: c# linq

我有这堂课:

class OriginalClass {
  string FirstItem;
  List<string> ListOfSecondItems;
}

我想将一个类的列表转换为另一个类的列表,或者将此类“展平”为新类:

class FlattenedClass {
  string First;
  string Second;
}

我正在使用此LINQ表达式从一个转换为另一个:

OriginalClass original;
var flattened = from Item in original
  from secondItem in item.ListOfSecondItems
  select new FlattenedClass(item.FirstItem, secondItem);

问题是如果第二项的列表为空我丢失了第一项。如果列表为null或为空,我想要使用一些“(默认)”值。我想DefaultIfEmpty是关键,但不知道如何将其合并到现有查询中。

1 个答案:

答案 0 :(得分:3)

DefaultIfEmpty的此调用说:“如果ListOfSecondItems为空,请使用单个null。”

var flattened =
  from Item in original
  from secondItem in item.ListOfSecondItems.DefaultIfEmpty()
  select new FlattenedClass(item.FirstItem, secondItem); 

您的问题提到ListOfSecondItems可能为null的可能性。此代码处理这种可能性。它还提供默认字符串而不是null(使用其他版本的DefaultIfEmpty)。

var flattened =
  from Item in original
  let subList = item.ListOfSecondItems ?? new List<string>()
  from secondItem in subList.DefaultIfEmpty("(default)")
  select new FlattenedClass(item.FirstItem, secondItem);