【问题标题】:How does this RavenDB linq query work这个 RavenDB linq 查询是如何工作的
【发布时间】:2012-02-27 02:36:51
【问题描述】:

我正在查看 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 太快了。

【问题讨论】:

    标签: linq ravendb


    【解决方案1】:

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

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

    【讨论】:

      猜你喜欢
      • 2018-11-25
      • 2017-05-31
      • 1970-01-01
      • 2023-02-11
      • 2012-08-31
      • 1970-01-01
      • 2011-04-13
      • 1970-01-01
      相关资源
      最近更新 更多