Estou tentando achatar objetos aninhados como este:
public class Book
{
public string Name { get; set; }
public IList<Chapter> Chapters { get; set; }
}
public class Chapter
{
public string Name { get; set; }
public IList<Page> Pages { get; set; }
}
public class Page
{
public string Name { get; set; }
}
Deixe-me fazer um exemplo. Estes são os dados que tenho
Book: Pro Linq
{
Chapter 1: Hello Linq
{
Page 1,
Page 2,
Page 3
},
Chapter 2: C# Language enhancements
{
Page 4
},
}
O resultado que estou procurando é a seguinte lista simples:
"Pro Linq", "Hello Linq", "Page 1"
"Pro Linq", "Hello Linq", "Page 2"
"Pro Linq", "Hello Linq", "Page 3"
"Pro Linq", "C# Language enhancements", "Page 4"
Como eu pude fazer isso? Eu poderia fazer isso com um novo select, mas me disseram que um SelectMany seria suficiente.
.Select(p => new FlatBook(b.Name, c.Name, p.Name))
myBooks.SelectMany(b => b.Chapters).SelectMany(c => c.Pages).Select(p => b.Name + ", " + c.Name + ", " + p.Name);
myBooks.SelectMany(b => b.Chapters == null || !b.Chapters.Any()? new []{b.Name + " has no Chapters"} : b.SelectMany(c => c.Pages.Select(p => b.Name + ", " + c.Name + ", " + p.Name)));
Assumindo que
books
é uma lista de livros:fonte
IEnumerable<Book>
o caso, não precisa de aList<Book>
.fonte
Eu estava tentando fazer isso também, e pelos comentários de Yuriy e mexendo com o linqPad, eu tenho isso.
Observe que não tenho livros, capítulos, páginas, tenho pessoa (livros), companyPerson (capítulos) e empresas (páginas)
ou
Site de referência que usei: http://odetocode.com/blogs/scott/archive/2008/03/25/inner-outer-lets-all-join-together-with-linq.aspx
fonte