gpt4 book ai didi

c# - Solr 的 Sitecore (ContentSearch) SeachMaxResults 可以在运行时重新定义吗?

转载 作者:太空宇宙 更新时间:2023-11-03 12:05:31 25 4
gpt4 key购买 nike

目前我使用的是默认配置值:

<setting name="ContentSearch.SearchMaxResults" value="500" />

对于特定的 Solr (ContentSearch) 查询,我需要返回特定模板 ID 的所有项目。退回的商品总数将超过 1200 件。

我尝试使用分页功能通过如下调用查询来覆盖 SearchMaxResults:

var query = context.GetQueryable<SearchResultItem>().Filter(i => i["_template"].Equals(variantTemplateId));
query = query.Page(1, 1500);
var results = query.GetResults();

但是,我仍然只收到包含 500 个项目的单页,因为 1500 页面大小不会覆盖 SearchMaxResults 值 500。

我真的不想增加所有查询的 SearchMaxResults,因为它会对搜索产生整体负面影响。如果我可以暂时将此参数设置为“”(无限结果),运行我的查询并将其重置为默认值,那将是理想的 - 但我没有看到能够做到这一点的方法。我也不能使用 GetDescendants() 作为获取所有这些项目的方法,因为它会对站点性能产生负面影响,即使我只执行一次并将结果存储在内存缓存中也是如此。

任何方向将不胜感激。

最佳答案

正如您所说,最好将 SearchMaxResults 保持在一个可重复的低数,例如 500。当您知道可能需要获取更多数据时,您可以在一个循环中执行多个查询,例如像这样:

int skip = 0;
const int chunkSize = 500;
bool fetchMore = true;
while (fetchMore) {
var q = context.GetQueryable<MyModel>()
.Filter(....)
...
.Skip(skip).Take(chunkSize)
.Select (d => new { d.field1, d.field2, ... })
.GetResults();
var cnt = 0;
foreach (var doc in q.Hits) {
// do stuff
cnt ++;
}
skip += cnt;
fetchMore = cnt == chunkSize;
}

如上所述,我使用了 Select 方法来限制返回的字段数。这将指定 fl Solr 字段以仅返回您需要的字段。否则 fl=*,score 将被使用并导致大量数据通过网络发送并且反序列化它可能非常繁重。 (我在这里有一个单独的帖子:https://mikael.com/2019/01/optimize-sitecore-solr-queries/)

关于c# - Solr 的 Sitecore (ContentSearch) SeachMaxResults 可以在运行时重新定义吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55252413/

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