gpt4 book ai didi

linq - 这个 RavenDB linq 查询是如何工作的

转载 作者:行者123 更新时间:2023-12-04 18:30:26 26 4
gpt4 key购买 nike

我正在查看 RacoonBlog 的源代码试图在 RavenDB 中找到一种方法来查询文档中包含的集合。我确实阅读了有关索引和 Map/Reduce 的信息,但未能找到我的答案。

在 PostsController 中有一个名为 Tag 的 ActionResult,它接受一个字符串参数并包含以下 linq 查询。

var posts = RavenSession.Query<Post>()
.Include(x => x.AuthorId)
.Statistics(out stats)
.WhereIsPublicPost()
.Where(post => post.TagsAsSlugs.Any(postTag => postTag == slug))
.OrderByDescending(post => post.PublishAt)
.Paging(CurrentPage, DefaultPage, PageSize)
.ToList();

Where 扩展方法调用 TagsAsSlugs 并执行 Any,TagsAsSlugs 看起来像这样。
    public IEnumerable<string> TagsAsSlugs
{
get
{
if (Tags == null)
yield break;
foreach (var tag in Tags)
{
yield return SlugConverter.TitleToSlug(tag);
}
}
}

那么,既然 TagsAsSlugs 属性循环遍历标签集合,那么查询是否要求返回所有帖子,以便每个帖子都可以迭代其标签集合?

我怀疑这是因为 Oren's blog是如此之快。

最佳答案

jackson ,
不,这不是它的工作原理。我们在索引期间做这项工作(TagAsSlugs 实际上是根据保存时间计算的),然后我们将 TagsAsSlugs 保存到索引中。
我们查询索引中存在的标签。

简而言之,我们不做任何计算,当然不在客户端。

关于linq - 这个 RavenDB linq 查询是如何工作的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9454300/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com