public class SortedNumericDocValuesField extends Field
Field that stores a per-document long values for scoring,
sorting or value retrieval. Here's an example usage:
document.add(new SortedNumericDocValuesField(name, 5L)); document.add(new SortedNumericDocValuesField(name, 14L));
Note that if you want to encode doubles or floats with proper sort order,
you will need to encode them with NumericUtils:
document.add(new SortedNumericDocValuesField(name, NumericUtils.floatToSortableInt(-5.3f)));
If you also need to store the value, you should add a
separate StoredField instance.
Field.Store| Modifier and Type | Field and Description |
|---|---|
static FieldType |
TYPE
Type for sorted numeric DocValues.
|
fieldsData, name, tokenStream, type| Constructor and Description |
|---|
SortedNumericDocValuesField(String name,
long value)
Creates a new DocValues field with the specified 64-bit long value
|
| Modifier and Type | Method and Description |
|---|---|
static Query |
newSlowExactQuery(String field,
long value)
Create a query for matching an exact long value.
|
static Query |
newSlowRangeQuery(String field,
long lowerValue,
long upperValue)
Create a range query that matches all documents whose value is between
lowerValue and upperValue included. |
binaryValue, fieldType, getCharSequenceValue, name, numericValue, readerValue, setBytesValue, setBytesValue, setByteValue, setDoubleValue, setFloatValue, setIntValue, setLongValue, setReaderValue, setShortValue, setStringValue, setTokenStream, stringValue, tokenStream, tokenStreamValue, toStringpublic static final FieldType TYPE
public SortedNumericDocValuesField(String name, long value)
name - field namevalue - 64-bit long valueIllegalArgumentException - if the field name is nullpublic static Query newSlowRangeQuery(String field, long lowerValue, long upperValue)
lowerValue and upperValue included.
You can have half-open ranges (which are in fact </≤ or >/≥ queries)
by setting lowerValue = Long.MIN_VALUE or upperValue = Long.MAX_VALUE.
Ranges are inclusive. For exclusive ranges, pass Math.addExact(lowerValue, 1)
or Math.addExact(upperValue, -1).
This query also works with fields that have indexed
NumericDocValuesFields.
NOTE: Such queries cannot efficiently advance to the next match,
which makes them slow if they are not ANDed with a selective query. As a
consequence, they are best used wrapped in an IndexOrDocValuesQuery,
alongside a range query that executes on points, such as
LongPoint.newRangeQuery(java.lang.String, long, long).
public static Query newSlowExactQuery(String field, long value)
This query also works with fields that have indexed
NumericDocValuesFields.
NOTE: Such queries cannot efficiently advance to the next match,
which makes them slow if they are not ANDed with a selective query. As a
consequence, they are best used wrapped in an IndexOrDocValuesQuery,
alongside a range query that executes on points, such as
LongPoint.newExactQuery(java.lang.String, long).
Copyright © 2000-2021 Apache Software Foundation. All Rights Reserved.