我们在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")
似乎造成了问题。当我们注释掉这一行时,它可以正常工作,但结果并没有明显排序。当我们把它重新放入时,同样的问题只返回几个结果。
我将一些事情重新命名为更有意义。如果需要更多信息,请告诉我。
感谢任何帮助或建议。
答案 0 :(得分:4)
我会假设where
中的TransformResults
。请注意,在发生分页后,TR会发生。所以你给它喂了100个项目,TR过滤掉它们,但是没有尝试获得任何额外的结果来填充页面的其余部分。
一般情况下,TR不应该进行过滤。
您应该在查询中执行此操作。