知道为什么这个RavenDB查询只返回6个结果吗?

时间:2013-03-25 01:39:45

标签: c# .net indexing ravendb

我们在Raven中对这个问题感到困惑,并且在我们的生活中无法弄清楚它有什么问题。我们有一个非常大的指数。它还有一个运行的转换,它根据包含标签数组的白名单文档过滤掉结果。

这是索引:

public class Entries_ByWhiteListSearchableFields
        : AbstractIndexCreationTask<Entry, Entries_ByWhiteListSearchableFields.Result>
    {
        public class Result
        {
            public string Id { get; set; }
            public IEnumerable<string> Search { get; set; }
            public DateTimeOffset? LastPublishedAtUtc { get; set; }
            public DateTimeOffset LastModifiedAtUtc { get; set; }
            public DateTimeOffset DisplayAtUtc { get; set; }
            public PublishStatus PublishStatus { get; set; }
            public IEnumerable<string> BylineIds { get; set; }
            public IEnumerable<string> TagIds { get; set; }
            public IEnumerable<string> ReferenceIds { get; set; }
            public string SourceStreamConfigId { get; set; }
            public bool Deleted { get; set; }
            public IEnumerable<string> FullyQualifiedTagIds { get; set; }
            public DateTimeOffset? ExpireAtUtc { get; set; }
        }

        public Entries_ByWhiteListSearchableFields()
        {
            this.Map = entries => from entry in entries
                                  let entrySection = entry.Tags.FirstOrDefault(tag => tag.Schema == "EntrySection")
                                  where entrySection != null
                                  select new
                                  {
                                      Id = entry.Id,
                                      Search = entry.Tags
                                          .Select(x => x.Label)
                                          .Concat(new[] { entry.Headline }),

                                      LastPublishedAtUtc = entry.LastPublishedAtUtc,
                                      LastModifiedAtUtc = entry.LastModifiedAtUtc,
                                      DisplayAtUtc = entry.LastPublishedAtUtc ?? entry.LastModifiedAtUtc,
                                      PublishStatus = entry.PublishStatus,
                                      BylineIds = entry.BylineIds,
                                      TagIds = entry.Tags.Select(x => x.Id),
                                      ReferenceIds = entry.References.Select(x => x.Id),
                                      Deleted = entry.Deleted,
                                      EntrySectionId = entrySection.Id,
                                      FullyQualifiedTagIds = entry.Tags.Select(t => t.Schema + "." + t.Id),
                                      ExpireAtUtc = entry.ExpireAtUtc
                                  };

            this.TransformResults =
                (database, entries) => from entry in entries
                                       let whitelist = database.Load<WhiteList>("whitelistdocid")
                                       where database.Load<Entry>(entry.Id)
                                                     .Tags
                                                     .Select(t => t.Schema + "." + t.Id)
                                                     .Intersect(
                                                        whitelist.WhiteList.Select(s => "EntrySection." + s))
                                                     .Any()
                                       select entry;
            this.Index(x => x.Search, FieldIndexing.Analyzed);
        }
    }

我们已经运行了这个完全相同的索引,但没有转换,它完美地运行。

这个索引似乎也有效,但在一个领域,我们有这个查询:

query = this.session.Advanced.LuceneQuery<Entry, Entries_ByWhiteListSearchableFields>()    
.Statistics(out stats)
.WhereEquals("Deleted", false)
.OrderBy("-DisplayAtUtc")
.Skip(queryModel.PageSize * (queryModel.Page - 1))
.Take(queryModel.PageSize)
.Include("BylineIds")
.Include("Tags,Id")
.Include("References,Id")
.Select(factory.GetEntryDashboardItemViewModel);

此查询在没有转换的情况下完成原始索引。但是,使用新索引时,当我们请求pageSize为100时,它只返回6个结果。当我们要求50时,它只返回几个。当我们要求25时,它返回0.

然而,这一行:

.OrderBy("-DisplayAtUtc")

似乎造成了问题。当我们注释掉这一行时,它可以正常工作,但结果并没有明显排序。当我们把它重新放入时,同样的问题只返回几个结果。

我将一些事情重新命名为更有意义。如果需要更多信息,请告诉我。

感谢任何帮助或建议。

1 个答案:

答案 0 :(得分:4)

我会假设where中的TransformResults。请注意,在发生分页后,TR会发生。所以你给它喂了100个项目,TR过滤掉它们,但是没有尝试获得任何额外的结果来填充页面的其余部分。

一般情况下,TR不应该进行过滤。

您应该在查询中执行此操作。