public class ReverseOrdFieldSource extends ValueSource
FieldCache
using getStringIndex()
and reverses the order.
The native lucene index order is used to assign an ordinal value for each field value.
Field values (terms) are lexicographically ordered by unicode value, and numbered starting at 1.
Example of reverse ordinal (rord):
If there were only three field values: "apple","banana","pear"
then rord("apple")=3, rord("banana")=2, ord("pear")=1
WARNING: rord() depends on the position in an index and can thus change when other documents are inserted or deleted, or if a MultiSearcher is used.
NOTE: with the switch in 2.9 to segment-based
searching, if getValues(org.apache.lucene.index.IndexReader)
is invoked with a
composite (multi-segment) reader, this can easily cause
double RAM usage for the values in the FieldCache. It's
best to switch your application to pass only atomic
(single segment) readers to this API.
Constructor and Description |
---|
ReverseOrdFieldSource(String field)
Contructor for a certain field.
|
Modifier and Type | Method and Description |
---|---|
String |
description()
description of field, used in explain()
|
boolean |
equals(Object o)
Needed for possible caching of query results - used by
ValueSourceQuery.equals(Object) . |
DocValues |
getValues(IndexReader reader)
Return the DocValues used by the function query.
|
int |
hashCode()
Needed for possible caching of query results - used by
ValueSourceQuery.hashCode() . |
toString
public String field
public ReverseOrdFieldSource(String field)
field
- field whose values reverse order is used.public String description()
ValueSource
description
in class ValueSource
public DocValues getValues(IndexReader reader) throws IOException
ValueSource
getValues
in class ValueSource
reader
- the IndexReader used to read these values.
If any caching is involved, that caching would also be IndexReader based.IOException
- for any error.public boolean equals(Object o)
ValueSource
ValueSourceQuery.equals(Object)
.equals
in class ValueSource
Object.equals(Object)
public int hashCode()
ValueSource
ValueSourceQuery.hashCode()
.hashCode
in class ValueSource
Object.hashCode()