Class TermOrdValComparator
java.lang.Object
org.apache.lucene.search.FieldComparator<BytesRef>
org.apache.lucene.search.comparators.TermOrdValComparator
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 SummaryNested classes/interfaces inherited from class org.apache.lucene.search.FieldComparatorFieldComparator.RelevanceComparator, FieldComparator.TermValComparator
- 
Constructor SummaryConstructorsConstructorDescriptionTermOrdValComparator(int numHits, String field, boolean sortMissingLast, boolean reverse, Pruning pruning) Creates this, with control over how missing values are sorted.
- 
Method SummaryModifier and TypeMethodDescriptionintcompare(int slot1, int slot2) Compare hit at slot1 with hit at slot2.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.voidInforms the comparator that the skipping of documents should be disabled.getLeafComparator(LeafReaderContext context) Get a per-segmentLeafFieldComparatorto collect the givenLeafReaderContext.protected SortedDocValuesgetSortedDocValues(LeafReaderContext context, String field) Retrieves the SortedDocValues for the field in this segmentvoidInforms the comparator that sort is done on this single field.voidsetTopValue(BytesRef value) Record the top value, for future calls toLeafFieldComparator.compareTop(int).value(int slot) Return the actual value in the slot.
- 
Constructor Details
- 
Method Details- 
disableSkippingpublic void disableSkipping()Description copied from class:FieldComparatorInforms the comparator that the skipping of documents should be disabled. This function is called by TopFieldCollector in cases when the skipping functionality should not be applied or not necessary. An example could be when search sort is a part of the index sort, and can be already efficiently handled by TopFieldCollector, and doing extra work for skipping in the comparator is redundant.- Overrides:
- disableSkippingin class- FieldComparator<BytesRef>
 
- 
setSingleSortpublic void setSingleSort()Description copied from class:FieldComparatorInforms the comparator that sort is done on this single field. This is useful to enable some optimizations for skipping non-competitive documents.- Overrides:
- setSingleSortin class- FieldComparator<BytesRef>
 
- 
comparepublic int compare(int slot1, int slot2) Description copied from class:FieldComparatorCompare hit at slot1 with hit at slot2.- Specified by:
- comparein class- FieldComparator<BytesRef>
- Parameters:
- slot1- first slot to compare
- slot2- 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
 
- 
getSortedDocValuesprotected SortedDocValues getSortedDocValues(LeafReaderContext context, String field) throws IOException Retrieves the SortedDocValues for the field in this segment- Throws:
- IOException
 
- 
getLeafComparatorDescription 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 class- FieldComparator<BytesRef>
- Parameters:
- context- current reader context
- Returns:
- the comparator to use for this segment
- Throws:
- IOException- if there is a low-level IO error
 
- 
setTopValueDescription 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 class- FieldComparator<BytesRef>
 
- 
valueDescription copied from class:FieldComparatorReturn the actual value in the slot.- Specified by:
- valuein class- FieldComparator<BytesRef>
- Parameters:
- slot- the value
- Returns:
- value in this slot
 
- 
compareValuesDescription 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 class- FieldComparator<BytesRef>
 
 
-