Package org.apache.lucene.search
Class FieldComparator.TermOrdValComparator
java.lang.Object
org.apache.lucene.search.FieldComparator<BytesRef>
org.apache.lucene.search.FieldComparator.TermOrdValComparator
- All Implemented Interfaces:
LeafFieldComparator
- Enclosing class:
- FieldComparator<T>
public static class FieldComparator.TermOrdValComparator
extends FieldComparator<BytesRef>
implements LeafFieldComparator
Sorts by field's natural Term sort order, using ordinals. This is functionally equivalent to
FieldComparator.TermValComparator, but it first resolves the
string to their relative ordinal positions (using the index returned by LeafReader.getSortedDocValues(String)), and does most comparisons
using the ordinals. For medium to large results, this comparator will be much faster than
FieldComparator.TermValComparator. For very small result sets
it may be slower.-
Nested Class Summary
Nested classes/interfaces inherited from class org.apache.lucene.search.FieldComparator
FieldComparator.RelevanceComparator, FieldComparator.TermOrdValComparator, FieldComparator.TermValComparator -
Field Summary
FieldsModifier and TypeFieldDescription(package private) int(package private) boolean(package private) int(package private) BytesRef(package private) intprivate final String(package private) final intWhich ordinal to use for a missing value.(package private) final int-1 if missing values are sorted first, 1 if they are sorted last(package private) final int[](package private) final int[]private final BytesRefBuilder[](package private) SortedDocValues(package private) int(package private) boolean(package private) BytesRefSet by setTopValue.(package private) final BytesRef[] -
Constructor Summary
ConstructorsConstructorDescriptionTermOrdValComparator(int numHits, String field) Creates this, sorting missing values first.TermOrdValComparator(int numHits, String field, boolean sortMissingLast) Creates this, with control over how missing values are sorted. -
Method Summary
Modifier and TypeMethodDescriptionintcompare(int slot1, int slot2) Compare hit at slot1 with hit at slot2.intcompareBottom(int doc) Compare the bottom of the queue with this doc.intcompareTop(int doc) Compare the top value with this doc.intcompareValues(BytesRef val1, BytesRef val2) Returns a negative integer if first is less than second, 0 if they are equal and a positive integer otherwise.voidcopy(int slot, int doc) This method is called when a new hit is competitive.getLeafComparator(LeafReaderContext context) Get a per-segmentLeafFieldComparatorto collect the givenLeafReaderContext.private intgetOrdForDoc(int doc) protected SortedDocValuesgetSortedDocValues(LeafReaderContext context, String field) Retrieves the SortedDocValues for the field in this segmentvoidsetBottom(int bottom) Set the bottom slot, ie the "weakest" (sorted last) entry in the queue.voidSets the Scorer to use in case a document's score is needed.voidsetTopValue(BytesRef value) Record the top value, for future calls toLeafFieldComparator.compareTop(int).value(int slot) Return the actual value in the slot.Methods inherited from class org.apache.lucene.search.FieldComparator
disableSkipping, setSingleSortMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.lucene.search.LeafFieldComparator
competitiveIterator, setHitsThresholdReached
-
Field Details
-
ords
final int[] ords -
values
-
tempBRs
-
readerGen
final int[] readerGen -
currentReaderGen
int currentReaderGen -
termsIndex
SortedDocValues termsIndex -
field
-
bottomSlot
int bottomSlot -
bottomOrd
int bottomOrd -
bottomSameReader
boolean bottomSameReader -
bottomValue
BytesRef bottomValue -
topValue
BytesRef topValueSet by setTopValue. -
topSameReader
boolean topSameReader -
topOrd
int topOrd -
missingSortCmp
final int missingSortCmp-1 if missing values are sorted first, 1 if they are sorted last -
missingOrd
final int missingOrdWhich ordinal to use for a missing value.
-
-
Constructor Details
-
TermOrdValComparator
Creates this, sorting missing values first. -
TermOrdValComparator
Creates this, with control over how missing values are sorted. Pass sortMissingLast=true to put missing values at the end.
-
-
Method Details
-
getOrdForDoc
- Throws:
IOException
-
compare
public int compare(int slot1, int slot2) Description copied from class:FieldComparatorCompare hit at slot1 with hit at slot2.- Specified by:
comparein classFieldComparator<BytesRef>- Parameters:
slot1- first slot to compareslot2- second slot to compare- Returns:
- any
N < 0if slot2's value is sorted after slot1, anyN > 0if the slot2's value is sorted before slot1 and0if they are equal
-
compareBottom
Description copied from interface:LeafFieldComparatorCompare the bottom of the queue with this doc. This will only invoked after setBottom has been called. This should return the same result asFieldComparator.compare(int,int)} as if bottom were slot1 and the new document were slot 2.For a search that hits many results, this method will be the hotspot (invoked by far the most frequently).
- Specified by:
compareBottomin interfaceLeafFieldComparator- Parameters:
doc- that was hit- Returns:
- any
N < 0if the doc's value is sorted after the bottom entry (not competitive), anyN > 0if the doc's value is sorted before the bottom entry and0if they are equal. - Throws:
IOException
-
copy
Description copied from interface:LeafFieldComparatorThis method is called when a new hit is competitive. You should copy any state associated with this document that will be required for future comparisons, into the specified slot.- Specified by:
copyin interfaceLeafFieldComparator- Parameters:
slot- which slot to copy the hit todoc- docID relative to current reader- Throws:
IOException
-
getSortedDocValues
protected SortedDocValues getSortedDocValues(LeafReaderContext context, String field) throws IOException Retrieves the SortedDocValues for the field in this segment- Throws:
IOException
-
getLeafComparator
Description copied from class:FieldComparatorGet a per-segmentLeafFieldComparatorto collect the givenLeafReaderContext. All docIDs supplied to thisLeafFieldComparatorare relative to the current reader (you must add docBase if you need to map it to a top-level docID).- Specified by:
getLeafComparatorin classFieldComparator<BytesRef>- Parameters:
context- current reader context- Returns:
- the comparator to use for this segment
- Throws:
IOException- if there is a low-level IO error
-
setBottom
Description copied from interface:LeafFieldComparatorSet the bottom slot, ie the "weakest" (sorted last) entry in the queue. WhenLeafFieldComparator.compareBottom(int)is called, you should compare against this slot. This will always be called beforeLeafFieldComparator.compareBottom(int).- Specified by:
setBottomin interfaceLeafFieldComparator- Parameters:
bottom- the currently weakest (sorted last) slot in the queue- Throws:
IOException
-
setTopValue
Description copied from class:FieldComparatorRecord the top value, for future calls toLeafFieldComparator.compareTop(int). This is only called for searches that use searchAfter (deep paging), and is called before any calls toFieldComparator.getLeafComparator(LeafReaderContext).- Specified by:
setTopValuein classFieldComparator<BytesRef>
-
value
Description copied from class:FieldComparatorReturn the actual value in the slot.- Specified by:
valuein classFieldComparator<BytesRef>- Parameters:
slot- the value- Returns:
- value in this slot
-
compareTop
Description copied from interface:LeafFieldComparatorCompare the top value with this doc. This will only invoked after setTopValue has been called. This should return the same result asFieldComparator.compare(int,int)} as if topValue were slot1 and the new document were slot 2. This is only called for searches that use searchAfter (deep paging).- Specified by:
compareTopin interfaceLeafFieldComparator- Parameters:
doc- that was hit- Returns:
- any
N < 0if the doc's value is sorted after the top entry (not competitive), anyN > 0if the doc's value is sorted before the top entry and0if they are equal. - Throws:
IOException
-
compareValues
Description copied from class:FieldComparatorReturns a negative integer if first is less than second, 0 if they are equal and a positive integer otherwise. Default impl to assume the type implements Comparable and invoke .compareTo; be sure to override this method if your FieldComparator's type isn't a Comparable or if your values may sometimes be null- Overrides:
compareValuesin classFieldComparator<BytesRef>
-
setScorer
Description copied from interface:LeafFieldComparatorSets the Scorer to use in case a document's score is needed.- Specified by:
setScorerin interfaceLeafFieldComparator- Parameters:
scorer- Scorer instance that you should use to obtain the current hit's score, if necessary.
-