Linq - 如何从仅包含其他列表项的列表中选择项目?

Gyp*_*psy 13 c# linq entity-framework

我有这两个班:

public class Item
{
   public int Id{get;set;}
   public List<Test> TestList{get;set;} 
}
public class Test
{ 
   public int Id{get;set;}
   public Item Item{get;set;}
   public byte State{get;set;}
}
Run Code Online (Sandbox Code Playgroud)

物品类别数据:

Id
 1
 2
 3
Run Code Online (Sandbox Code Playgroud)

和测试类数据:

Item   State
  1      1
  1      2
  1      3
  2      1
  2      4
  3      2
Run Code Online (Sandbox Code Playgroud)

现在我需要编写一个查询,从我的类中选择只有状态1和2的Items.例如,对于上面的示例,它应返回Item = 3的行.我写了这个查询:

var stateList=new List<byte>(){1,2};
Items.Where(x => x.TestList.Select(c => c.State).Any(s => stateList.Contains(s)));
Run Code Online (Sandbox Code Playgroud)

但它也返回Item = 1.任何想法?

Ahm*_*IEM 18

这将返回所有州所在的项目stateList,我认为这就是您所需要的:

Items.Where(x => x.TestList.All(s => stateList.Contains(s.State)));
Run Code Online (Sandbox Code Playgroud)