我有一个实体让我们称之为Blog
。每个Blog
实体都有许多Keyword
。 2通过关键字表格上的fk相关。
我有一个像FindAllBlogByKeywords(IEnumerable<string> keywords)
如何编写linq查询以提取与参数中所有关键字匹配的博客。
问题是EF不允许可枚举和表之间的连接。它不包含因为我希望查询匹配所有关键字,而不仅仅是任何一个 - 除了我有2个关键字列表,我需要参数中的关键字作为持久性中关键字的子集。
答案 0 :(得分:6)
您可以为每个关键字添加.Where子句:
IEnumerable<Blog> FindAllBlogByKeywords(IEnumerable<string> keywords)
{
IQueryable<Blog> query = context.Blogs;
foreach(string key in keywords)
query = query.Where(blog => blog.Keywords.Contains(key));
// Execute query (optional)
return query.ToList();
}
这是有效的,因为查询执行被推迟到结束。通过链接多个.Where
子句,您可以有效地创建“ALL”语句。