public abstract class DocValuesRangeFilter<T> extends Filter
LeafReader.getNumericDocValues(String)
).
DocValuesRangeFilter
builds a single cache for the field the first time it is used.
Each subsequent DocValuesRangeFilter
on the same field then reuses this cache,
even if the range itself changes.
This means that DocValuesRangeFilter
is much faster (sometimes more than 100x as fast)
as building a TermRangeFilter
, if using a newStringRange(java.lang.String, java.lang.String, java.lang.String, boolean, boolean)
.
However, if the range never changes it is slower (around 2x as slow) than building
a CachingWrapperFilter on top of a single TermRangeFilter
.
For numeric data types, this filter may be significantly faster than NumericRangeFilter
.
Furthermore, it does not need the numeric values encoded
by IntField
, FloatField
, LongField
or DoubleField
. But
it has the problem that it only works with exact one value/document (see below).
As with all LeafReader.getNumericDocValues(java.lang.String)
based functionality,
DocValuesRangeFilter
is only valid for
fields which exact one term for each document (except for newStringRange(java.lang.String, java.lang.String, java.lang.String, boolean, boolean)
where 0 terms are also allowed). Due to historical reasons, for numeric ranges
all terms that do not have a numeric value, 0 is assumed.
Thus it works on dates, prices and other single value fields but will not work on
regular text fields. It is preferable to use a NOT_ANALYZED
field to ensure that
there is only a single term.
This class does not have an constructor, use one of the static factory methods available, that create a correct instance for different data types.
Modifier and Type | Method and Description |
---|---|
boolean |
equals(Object o) |
abstract DocIdSet |
getDocIdSet(LeafReaderContext context,
Bits acceptDocs)
This method is implemented for each data type
|
String |
getField()
Returns the field name for this filter
|
T |
getLowerVal()
Returns the lower value of this range filter
|
T |
getUpperVal()
Returns the upper value of this range filter
|
int |
hashCode() |
boolean |
includesLower()
Returns
true if the lower endpoint is inclusive |
boolean |
includesUpper()
Returns
true if the upper endpoint is inclusive |
static DocValuesRangeFilter<BytesRef> |
newBytesRefRange(String field,
BytesRef lowerVal,
BytesRef upperVal,
boolean includeLower,
boolean includeUpper)
Creates a BytesRef range filter using
LeafReader.getSortedDocValues(String) . |
static DocValuesRangeFilter<Double> |
newDoubleRange(String field,
Double lowerVal,
Double upperVal,
boolean includeLower,
boolean includeUpper)
Creates a numeric range filter using
LeafReader.getNumericDocValues(String) . |
static DocValuesRangeFilter<Float> |
newFloatRange(String field,
Float lowerVal,
Float upperVal,
boolean includeLower,
boolean includeUpper)
Creates a numeric range filter using
LeafReader.getNumericDocValues(String) . |
static DocValuesRangeFilter<Integer> |
newIntRange(String field,
Integer lowerVal,
Integer upperVal,
boolean includeLower,
boolean includeUpper)
Creates a numeric range filter using
LeafReader.getSortedDocValues(String) . |
static DocValuesRangeFilter<Long> |
newLongRange(String field,
Long lowerVal,
Long upperVal,
boolean includeLower,
boolean includeUpper)
Creates a numeric range filter using
LeafReader.getNumericDocValues(String) . |
static DocValuesRangeFilter<String> |
newStringRange(String field,
String lowerVal,
String upperVal,
boolean includeLower,
boolean includeUpper)
Creates a string range filter using
LeafReader.getSortedDocValues(String) . |
String |
toString() |
public abstract DocIdSet getDocIdSet(LeafReaderContext context, Bits acceptDocs) throws IOException
getDocIdSet
in class Filter
context
- a LeafReaderContext
instance opened on the index currently
searched on. Note, it is likely that the provided reader info does not
represent the whole underlying index i.e. if the index has more than
one segment the given reader only represents a single segment.
The provided context is always an atomic context, so you can call
LeafReader.fields()
on the context's reader, for example.acceptDocs
- Bits that represent the allowable docs to match (typically deleted docs
but possibly filtering other documents)null
should be returned if
the filter doesn't accept any documents otherwise internal optimization might not apply
in the case an empty DocIdSet
is returned.IOException
public static DocValuesRangeFilter<String> newStringRange(String field, String lowerVal, String upperVal, boolean includeLower, boolean includeUpper)
LeafReader.getSortedDocValues(String)
. This works with all
fields containing zero or one term in the field. The range can be half-open by setting one
of the values to null
.public static DocValuesRangeFilter<BytesRef> newBytesRefRange(String field, BytesRef lowerVal, BytesRef upperVal, boolean includeLower, boolean includeUpper)
LeafReader.getSortedDocValues(String)
. This works with all
fields containing zero or one term in the field. The range can be half-open by setting one
of the values to null
.public static DocValuesRangeFilter<Integer> newIntRange(String field, Integer lowerVal, Integer upperVal, boolean includeLower, boolean includeUpper)
LeafReader.getSortedDocValues(String)
. This works with all
int fields containing exactly one numeric term in the field. The range can be half-open by setting one
of the values to null
.public static DocValuesRangeFilter<Long> newLongRange(String field, Long lowerVal, Long upperVal, boolean includeLower, boolean includeUpper)
LeafReader.getNumericDocValues(String)
. This works with all
long fields containing exactly one numeric term in the field. The range can be half-open by setting one
of the values to null
.public static DocValuesRangeFilter<Float> newFloatRange(String field, Float lowerVal, Float upperVal, boolean includeLower, boolean includeUpper)
LeafReader.getNumericDocValues(String)
. This works with all
float fields containing exactly one numeric term in the field. The range can be half-open by setting one
of the values to null
.public static DocValuesRangeFilter<Double> newDoubleRange(String field, Double lowerVal, Double upperVal, boolean includeLower, boolean includeUpper)
LeafReader.getNumericDocValues(String)
. This works with all
double fields containing exactly one numeric term in the field. The range can be half-open by setting one
of the values to null
.public String getField()
public boolean includesLower()
true
if the lower endpoint is inclusivepublic boolean includesUpper()
true
if the upper endpoint is inclusivepublic T getLowerVal()
public T getUpperVal()
Copyright © 2000-2015 Apache Software Foundation. All Rights Reserved.