Linq与实体连接可枚举

时间:2012-07-10 19:39:10

标签: c# .net linq entity-framework join

我有一个实体让我们称之为Blog。每个Blog实体都有许多Keyword。 2通过关键字表格上的fk相关。

我有一个像FindAllBlogByKeywords(IEnumerable<string> keywords)

这样的签名的查询

如何编写linq查询以提取与参数中所有关键字匹配的博客。

问题是EF不允许可枚举和表之间的连接。它不包含因为我希望查询匹配所有关键字,而不仅仅是任何一个 - 除了我有2个关键字列表,我需要参数中的关键字作为持久性中关键字的子集。

1 个答案:

答案 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”语句。