LINQ列表列表

时间:2013-08-12 08:45:42

标签: c# .net linq

  public class Employee
    { 
        public string  Name{get;set;}
        public List<Department> Department { get; set; }
        public string Company{get;set;}
    }

    public class Department
    {
        public string Name { get; set; }
        public string Location { get; set; }
    }

   List<Employee> employees = new List<Employee>();
        employees.Add(new Employee() { Company = "Dell", Name = "ABC" });
        employees.Add(new Employee() { Company = "Dell", Name = "Aakash" });
        employees.Add(new Employee() { Company = "CSC", Name = "Vaibhav" });
        employees.Add(new Employee() { Company = "TCS", Name = "Sambhav" });

        employees[0].Department = new List<Department>();
        employees[0].Department.Add(new Department() { Location = "Delhi", Name = "HR" });
        employees[0].Department.Add(new Department() { Location = "Delhi", Name = "Recruitment" });

        employees[1].Department = new List<Department>();
        employees[1].Department.Add(new Department() { Location = "Noida", Name = "EAO" });
        employees[1].Department.Add(new Department() { Location = "Delhi", Name = "Arch" });

        employees[2].Department = new List<Department>();
        employees[2].Department.Add(new Department() { Location = "Denmark", Name = "Scandi" });
        employees[2].Department.Add(new Department() { Location = "Noida", Name = "SAG" });

        employees[3].Department = new List<Department>();
        employees[3].Department.Add(new Department() { Location = "Mumbai", Name = "NSE" });

我需要编写一个lambda表达式来选择Departement Location为Noida的所有员工

2 个答案:

答案 0 :(得分:7)

使用Any扩展方法:

var results = employees.Where(e => e.Department.Any(d => d.Location == "Noida"))
                       .ToList();

答案 1 :(得分:1)

实际上你甚至不需要LINQ。 List<T>有方法FindAllExsists,可以完成这项工作:

employees.FindAll(e => e.Department.Exists(d => d.Location == "Noida"))