SOLR-9772: reuse comparator when deriving fieldSortValues

This commit is contained in:
yonik 2016-11-17 10:56:37 -05:00
parent 4fedb640ab
commit e525cca017
2 changed files with 8 additions and 5 deletions

View File

@ -75,6 +75,9 @@ Optimizations
* SOLR-9726: Reduce number of lookupOrd calls made by the DocValuesFacets.getCounts method.
(Jonny Marks via Christine Poerschke)
* SOLR-9772: Deriving distributed sort values (fieldSortValues) should reuse
comparator and only invalidate leafComparator. (John Call via yonik)
Bug Fixes
----------------------
* SOLR-9701: NPE in export handler when "fl" parameter is omitted.

View File

@ -617,7 +617,7 @@ public class QueryComponent extends SearchComponent
// :TODO: would be simpler to always serialize every position of SortField[]
if (type==SortField.Type.SCORE || type==SortField.Type.DOC) continue;
FieldComparator<?> comparator = null;
FieldComparator<?> comparator = sortField.getComparator(1,0);
LeafFieldComparator leafComparator = null;
Object[] vals = new Object[nDocs];
@ -634,13 +634,13 @@ public class QueryComponent extends SearchComponent
idx = ReaderUtil.subIndex(doc, leaves);
currentLeaf = leaves.get(idx);
if (idx != lastIdx) {
// we switched segments. invalidate comparator.
comparator = null;
// we switched segments. invalidate leafComparator.
lastIdx = idx;
leafComparator = null;
}
}
if (comparator == null) {
comparator = sortField.getComparator(1,0);
if (leafComparator == null) {
leafComparator = comparator.getLeafComparator(currentLeaf);
}