我似乎遇到了麻烦。我有一个带有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”,“可移植性”,“测试”并且我搜索“测试”和“可移植性”,那么该任务仍将显示。
答案 0 :(得分:3)
使用All而不是Any;并且只选择具有所有tags
(但可能更多)的KnowledgeBaseTasks;扭转表达方式:
var tasks = (from t in _context.KnowledgeBaseTasks
where tags.All(tag => t.KnowledgeBaseTaskTags.Contains(tag))
select KnowledgeBaseTaskViewModel.ConvertFromEntity(t)
).ToList();
答案 1 :(得分:2)
您想要this
LinqToSql可能看起来像:
List<int> myTags = GetTagIds();
int tagCount = myTags.Count;
IQueryable<int> 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<Content> query = myDC.Contents
.Where(c => subQuery.Contains(c.ContentId));
我没有对此进行过测试,并且Distinct位可能会稍微偏离。检查生成的sql以确定。