5

我希望更多地了解 LINQ 并更多地使用它,所以在这里进行一些自我开发工作......

我有一个对象如下:

public class Player(){

    public string Name{get;set;}

    public Club currentClub{get;set;}

    public IEnumerable<Club> previousClubs{get;set;}

}

现在,给定一个球员名单,我想选择以前为各种选定俱乐部效力的球员,我可以通过嵌套的几个 foreach 语句轻松完成 - 但我想用 Linq 来完成。 .

我已经尝试过了,但没有返回任何内容:

var prevClubs = 
    from player in players
    from clubOriginal in player.previousClubs
    from clubSecond in player.previousClubs
    from clubThird in player.previousClubs
    where clubOriginal.ID == 1
    where clubSecond.ID == 2
    where clubThird.ID == 3
    select new HistoryOfPlayer{ 
        firstClub == clubOriginal.Name,
        secondClub == clubSecond.Name,
        thirdClub == clubThird.Name
    }

对我哪里出错有帮助吗?数据肯定存在,因为当我有一个循环遍历球员的循环内的俱乐部循环时,我返回了为俱乐部 1,2 和 3 效力过的所有球员的集合,有数据......

实际上,它应该返回 HistoryOfPlayer 对象的几个实例,所有实例都包含相同 3 个俱乐部的名称(假设它们在 ID 上链接) - 正如我所说,它有点自学,所以尝试将它应用到运动中有点卡在我的脑海里!!

有人可以帮忙吗?

4

1 回答 1

4

你可以让它更有活力

List<int> clubIds = new List<int> { 1, 2, 3};
var prevClubs = from player in players
                where player.previousClubs.Any(m => clubIds.Contains(m.ID))
                select new HistoryOfPlayer {
                   Player = player, 
                   Clubs = player.previousClubs
                                 .Where(m => clubIds.Contains(m.ID))
                                 .Select(c => c.Name) 
                };

在 svik 之后编辑他的评论:

List<int> clubIds = new List<int> { 1, 2, 3};
var prevClubs = from player in players
                where clubIds.All(id => player.previousClubs
                                              .select(club => club.ID)
                                              .contains(id))
                select new HistoryOfPlayer {
                   Player = player, 
                   Clubs = player.previousClubs
                                 .Where(m => clubIds.Contains(m.ID))
                                 .Select(c => c.Name) 
                };

*注意这是在没有 IDE 的情况下编写的,所以我没有检查它是否有效。

于 2012-04-30T12:43:10.257 回答