Given a list of Parent objects that each have a list of Child objects, I want to find the child object matching a specific ID.
public class Parent
{
public int ID { get; set; }
public List<Child> Children { get; set; }
}
public class Child
{
public int ID { get; set; }
}
Now I want the Child object having a specific ID:
List<Parent> parents = GetParents();
Child childWithId17 = ???
How can I do this using Linq?
I think you want:
Child childWithId17 = parents.SelectMany(parent => parent.Children)
.FirstOrDefault(child => child.ID == 17);
Note that this assumes that Parent's Children property won't be a null-reference or contain null Child references.
You can use SelectMany:
Child childWithId17 = parents.SelectMany(p => p.Children)
.Where(ch=>ch.ID==17)
.FirstOrDefault();
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With