我对我的表使用多对多关系。
有一个查询:
var query = from post in context.Posts
from tag in post.Tags where tag.TagId == 10
select post;好的,它工作得很好。我得到的帖子有id指定的标签。
我有一个标签ids的集合。我想得到我收藏中的每一个标签的帖子。
我尝试以下方法:
var tagIds = new int[]{1, 3, 7, 23, 56};
var query = from post in context.Posts
from tag in post.Tags where tagIds.Contains( tag.TagId )
select post;它不起作用。该查询返回具有任何一个指定标签的所有帖子。
我想要得到一个像这样的子句,但对于集合中的任何标签计数都是动态的:
post.Tags.Whare(x => x.TagId = 1 && x.TagId = 3 && x.TagId = 7 && ... )发布于 2012-05-09 04:01:01
这实际上很容易做到:
var tags = context.Posts.Where(post => post.Tags.All(tag => tagIds.Contains(tag)));发布于 2012-05-09 04:04:52
如果您希望标签集合仅包含您指定的集合,而不包含其他集合,则另一个选项是使两个列表相交:
var query = from post in context.Posts
let tags = post.Tags.Select(x => x.Id).ToList()
where tags.Intersect(tagIds).Count() == tags.Length
select post;发布于 2012-05-09 04:01:04
在Any上试试吧。
var query = from post in context.Posts
from tag in post.Tags where tagIds.Any(t => t == tag.TagId )
select post;https://stackoverflow.com/questions/10505595
复制相似问题