public class ClassA
{
public string MyString {get; set;}
}
public class ClassB
{
public List<ClassA> MyObjects {get; set;}
}
List<ClassB> classBList = new List<ClassB>();
var results = (from i in classBList select i.MyObjects).Distinct();
I want a distinct list of all the ClassA
objects in the classBList
. How do I go about this using LINQ? I'm thinking about a nested query, but couldn't quite figure it out. Any help is very appreciated.
You're trying to select multiple result objects for each
ClassB
object in the original list.Therefore, you're looking for the
SelectMany
extension method:If you want to use query expressions, you'll need to use two
from
clauses:You want to use
IEnumerable.SelectMany()
Extension Method to flatten the hierarchy: