我的 LINQ 查询没有对我的字典进行排序

My LINQ query is not ordering my dictionary

我有字典

Dictionary<string, List<Employee>> employees

其中包含员工列表。我想允许用户根据他们所在的州按字母顺序显示员工列表。

Console.WriteLine($"If you would like to sort this list please enter one of the following choices..\n" +
                    $"'STATE', 'INCOME', 'ID', 'NAME', 'TAX' other wise enter any key.");
var sort = Console.ReadLine().ToUpper();

var employees = EmployeeRecord.employees;
List<Employee> sortedEmps = new List<Employee>();

if (sort.Contains("STATE")) 
   foreach (var list in employees.Values) {
       var columnQuery = list.OrderBy(x => x.stateCode).ToList();
       sortedEmps.AddRange(columnQuery);
   }
    
    
}
//Print out the newly ordered list
foreach (Employee r in sortedEmps) {   
    Console.WriteLine($"ID: {r.iD} Name: {r.name} State: {r.stateCode} Income:{r.income} Tax Due: {r.taxDue}"); 
}

但是,它仍然打印出没有排序的列表。我怎样才能让它按州代码的字母顺序排序?

合并所有数据后尝试排序。

if (sort.Contains("STATE")) {
   foreach (var list in employees.Values) {
       sortedEmps.AddRange(list);
   }
sortedEmps = sortedEmps.OrderBy(x => x.stateCode).ToList();
}

您还可以按照@Robert Harvey 的建议使用 SelectMany 缩短代码

if (sort.Contains("STATE")) {
    sortedEmps  = employees.Values              
                 .SelectMany(x => x)
                 .ToList().OrderBy(o => o.stateCode).ToList();
}