目前我使用的默认配置值为:
<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/)