如何检索在linq中使用所有提供的标签标记的项目?

我似乎遇到了麻烦。 我有一个带有ID的Task表和一个Tag表,它有一个标记字段和一个外键约束到任务表。

我希望能够通过标签执行AND搜索任务。 因此,例如,如果我搜索带有“可移植性”和“测试”标签的任务,我不希望任务标记为“可移植性”而不是“测试”。

我尝试了以下语法:

var tasks = (from t in _context.KnowledgeBaseTasks where t.KnowledgeBaseTaskTags.Any(x => tags.Contains(x.tag)) select KnowledgeBaseTaskViewModel.ConvertFromEntity(t) ).ToList(); 

这当然是OR搜索,而不是AND搜索。 我无法弄清楚如何将其切换为AND搜索。

编辑我还需要能够搜索任务包含的X标签中的2个。 因此,如果任务标记为“bugfix”,“可移植性”,“测试”并且我搜索“测试”和“可移植性”,那么该任务仍将显示。

你想这样做

LinqToSql可能看起来像:

 List myTags = GetTagIds(); int tagCount = myTags.Count; IQueryable subquery = from tag in myDC.Tags where myTags.Contains(tag.TagId) group tag.TagId by tag.ContentId into g where g.Distinct().Count() == tagCount select g.Key; IQueryable query = myDC.Contents .Where(c => subQuery.Contains(c.ContentId)); 

我没有对此进行过测试,并且Distinct位可能会稍微偏离。 检查生成的sql以确定。

使用All而不是Any; 并且只选择具有所有tags (但可能更多)的KnowledgeBaseTasks; 扭转表达方式:

 var tasks = (from t in _context.KnowledgeBaseTasks where tags.All(tag => t.KnowledgeBaseTaskTags.Contains(tag)) select KnowledgeBaseTaskViewModel.ConvertFromEntity(t) ).ToList();