C# 多个OrderBy未正确排序
我尝试按周排序,然后在我的SQL表中排序(最终结果应该按id一起进行训练,然后按指定的顺序排序),但它给出了错误的顺序。我的LINQ声明有什么问题吗C# 多个OrderBy未正确排序,c#,linq,C#,Linq,我尝试按周排序,然后在我的SQL表中排序(最终结果应该按id一起进行训练,然后按指定的顺序排序),但它给出了错误的顺序。我的LINQ声明有什么问题吗 private List<Workout> GetWorkouts(int id) { return new OPPDBContext().Workouts .Where(p=>p.ClientId == id).OrderBy(p => p.Order).OrderBy(p => p.Week
private List<Workout> GetWorkouts(int id)
{
return new OPPDBContext().Workouts
.Where(p=>p.ClientId == id).OrderBy(p => p.Order).OrderBy(p => p.WeekId).ToList();
}
这是因为第二个
.OrderBy
替换了第一个.OrderBy
(您按ClientId排序,然后实际上放弃了它,按WeekId排序)
您需要使用.OrderBy(…)。然后使用by(…)
:
return new OPPDBContext().Workouts.Where(p=>p.ClientId == id).OrderBy(p => p.Order).ThenBy(p => p.WeekId).ToList();
这是因为第二个
.OrderBy
替换了第一个.OrderBy
(您正在按ClientId排序,然后实际放弃它以按WeekId排序)
您需要使用.OrderBy(…)。然后使用by(…)
:
return new OPPDBContext().Workouts.Where(p=>p.ClientId == id).OrderBy(p => p.Order).ThenBy(p => p.WeekId).ToList();