繁体   English   中英

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

[英]How do I retrieve items that are tagged with all the supplied tags in linq?

我似乎对此有麻烦。 我有一个带有ID的任务表和一个Tag表,该表具有一个标记字段和对该任务表的外键约束。

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

我尝试了以下语法:

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

当然,这会执行“或”搜索,而不是“与”搜索。 我不知道如何实际将其切换为AND搜索。

编辑我还需要能够从任务包含的X个标记中搜索2个。 因此,如果任务被标记为“错误修正”,“可移植性”,“测试”,而我搜索“测试”和“可移植性”,则该任务仍会显示。

使用全部而不是任何; 为了只选择KnowledgeBaseTasks,它具有所有tags (但可能还有更多tags ); 反转表达式:

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

你想要做这个

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以确保。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM