15

我有这两个类:

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;}
}

项目类别数据:

Id
 1
 2
 3

和测试类数据:

Item   State
  1      1
  1      2
  1      3
  2      1
  2      4
  3      2

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

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

但它也返回 Item=1。有什么想法吗?

4

3 回答 3

21

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

Items.Where(x => x.TestList.All(s => stateList.Contains(s.State)));
于 2013-06-25T13:04:26.227 回答
4

如果您只需要那些 TestList 只有状态为 2 的项目:

tems.Where( i => i.TestList.All(li => li.State == 2))
于 2013-06-25T13:13:05.243 回答
0

我有类似的问题:

这是代码:

List<string> mds = _userService.GetAllMDUsers();
conf = _context.BillingsConfirmationsView.Where(c=> mds.Contains(c.EmployeeShort.ToUpper()));

我对以下情况有疑问。假设我有一个短“js”的员工,在我的 mds 列表中我有另一个短 jsc 的员工。现在我找回了两个员工的记录,我应该只得到 jsc,因为 js 不是 mds 的成员。现在我明白这是因为“js”是“jsc”的子集,但不知道如何获得正确的结果。EmployeeShort 是 BillingsConfirmationsView 模型中的字符串。

伊万

于 2022-02-03T12:06:28.370 回答