简体   繁体   中英

Find child objects in list of parent objects using LINQ

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();

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM