私は次の学生リストを持っています
IList<Student> studentList = new List<Student>() {
new Student() { StudentID = 1, StudentName = "John", Age = 13 ,Version =1 , Group=1} ,
new Student() { StudentID = 2, StudentName = "Moin", Age = 21 ,Version =2 , Group=1} ,
new Student() { StudentID = 3, StudentName = "Bill", Age = 18,Version=1,Group=2} ,
new Student() { StudentID = 4, StudentName = "Ram" , Age = 20 ,Version =1, Group=3} ,
new Student() { StudentID = 5, StudentName = "Ron" , Age = 15 ,Version =1, Group=5} ,
new Student() { StudentID = 6, StudentName = "yim" , Age = 25 ,Version =2 ,Group=5} ,
};
各グループの最大バージョンを含むリストを取得するにはどうすればよいですか?適切なLINQクエリは何ですか?
出力は次のようになります。
{ StudentID = 2, StudentName = "Moin", Age = 21 ,Version =2 , Group=1},
{ StudentID = 3, StudentName = "Bill", Age = 18 ,Version =1 , Group=2},
{ StudentID = 4, StudentName = "Ram" , Age = 20 ,Version =1 , Group=3},
{ StudentID = 6, StudentName = "yim" , Age = 25 ,Version =2 ,Group=5},
どうですか
var results = studentList.GroupBy(x => x.Group)
.Select(x => x.OrderByDescending(xx => xx.Version).First())
.ToList();
それらをGroup
でグループ化し、次にグループ化をVersion
降順で並べ替え、最初のグループ化を取得します。
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加