Class FunctionMatchQuery
- java.lang.Object
-
- org.apache.lucene.search.Query
-
- org.apache.lucene.queries.function.FunctionMatchQuery
-
public final class FunctionMatchQuery extends Query
A query that retrieves all documents with aDoubleValuesvalue matching a predicate This query works by a linear scan of the index, and is best used in conjunction with other queries that can restrict the number of documents visited
-
-
Field Summary
Fields Modifier and Type Field Description (package private) static floatDEFAULT_MATCH_COSTprivate java.util.function.DoublePredicatefilterprivate floatmatchCostprivate DoubleValuesSourcesource
-
Constructor Summary
Constructors Constructor Description FunctionMatchQuery(DoubleValuesSource source, java.util.function.DoublePredicate filter)Create a FunctionMatchQuery with default TwoPhaseIterator matchCost -DEFAULT_MATCH_COST= 100.0fFunctionMatchQuery(DoubleValuesSource source, java.util.function.DoublePredicate filter, float matchCost)Create a FunctionMatchQuery
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description WeightcreateWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost)Expert: Constructs an appropriate Weight implementation for this query.booleanequals(java.lang.Object o)Override and implement query instance equivalence properly in a subclass.inthashCode()Override and implement query hash code properly in a subclass.java.lang.StringtoString(java.lang.String field)Prints a query to a string, withfieldassumed to be the default field and omitted.voidvisit(QueryVisitor visitor)Recurse through the query tree, visiting any child queries-
Methods inherited from class org.apache.lucene.search.Query
classHash, rewrite, sameClassAs, toString
-
-
-
-
Field Detail
-
DEFAULT_MATCH_COST
static final float DEFAULT_MATCH_COST
- See Also:
- Constant Field Values
-
source
private final DoubleValuesSource source
-
filter
private final java.util.function.DoublePredicate filter
-
matchCost
private final float matchCost
-
-
Constructor Detail
-
FunctionMatchQuery
public FunctionMatchQuery(DoubleValuesSource source, java.util.function.DoublePredicate filter)
Create a FunctionMatchQuery with default TwoPhaseIterator matchCost -DEFAULT_MATCH_COST= 100.0f- Parameters:
source- aDoubleValuesSourceto use for valuesfilter- the predicate to match against
-
FunctionMatchQuery
public FunctionMatchQuery(DoubleValuesSource source, java.util.function.DoublePredicate filter, float matchCost)
Create a FunctionMatchQuery- Parameters:
source- aDoubleValuesSourceto use for valuesfilter- the predicate to match againstmatchCost- to be returned byTwoPhaseIterator.matchCost()
-
-
Method Detail
-
toString
public java.lang.String toString(java.lang.String field)
Description copied from class:QueryPrints a query to a string, withfieldassumed to be the default field and omitted.
-
visit
public void visit(QueryVisitor visitor)
Description copied from class:QueryRecurse through the query tree, visiting any child queries
-
createWeight
public Weight createWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost) throws java.io.IOException
Description copied from class:QueryExpert: Constructs an appropriate Weight implementation for this query.Only implemented by primitive queries, which re-write to themselves.
- Overrides:
createWeightin classQueryscoreMode- How the produced scorers will be consumed.boost- The boost that is propagated by the parent queries.- Throws:
java.io.IOException
-
equals
public boolean equals(java.lang.Object o)
Description copied from class:QueryOverride and implement query instance equivalence properly in a subclass. This is required so thatQueryCacheworks properly. Typically a query will be equal to another only if it's an instance of the same class and its document-filtering properties are identical that other instance. Utility methods are provided for certain repetitive code.- Specified by:
equalsin classQuery- See Also:
Query.sameClassAs(Object),Query.classHash()
-
hashCode
public int hashCode()
Description copied from class:QueryOverride and implement query hash code properly in a subclass. This is required so thatQueryCacheworks properly.- Specified by:
hashCodein classQuery- See Also:
Query.equals(Object)
-
-