Я не знаю, чи можливо це в Linq, але тут іде ...
У мене є об’єкт:
public class User
{
public int UserID { get; set; }
public string UserName { get; set; }
public int GroupID { get; set; }
}
Я повертаю список, який може виглядати наступним чином:
List<User> userList = new List<User>();
userList.Add( new User { UserID = 1, UserName = "UserOne", GroupID = 1 } );
userList.Add( new User { UserID = 2, UserName = "UserTwo", GroupID = 1 } );
userList.Add( new User { UserID = 3, UserName = "UserThree", GroupID = 2 } );
userList.Add( new User { UserID = 4, UserName = "UserFour", GroupID = 1 } );
userList.Add( new User { UserID = 5, UserName = "UserFive", GroupID = 3 } );
userList.Add( new User { UserID = 6, UserName = "UserSix", GroupID = 3 } );
Я хочу мати змогу запустити запит Linq у наведеному вище списку, який групує всіх користувачів за допомогою GroupID. Тож результатом буде список списків користувачів, який містить користувача (якщо це має сенс?). Щось на зразок:
GroupedUserList
UserList
UserID = 1, UserName = "UserOne", GroupID = 1
UserID = 2, UserName = "UserTwo", GroupID = 1
UserID = 4, UserName = "UserFour", GroupID = 1
UserList
UserID = 3, UserName = "UserThree", GroupID = 2
UserList
UserID = 5, UserName = "UserFive", GroupID = 3
UserID = 6, UserName = "UserSix", GroupID = 3
Я намагався використовувати пункт groupby linq, але це, здається, повертає список ключів і його не групується правильно:
var groupedCustomerList = userList.GroupBy( u => u.GroupID ).ToList();