Class ContextQuery
- java.lang.Object
-
- org.apache.lucene.search.Query
-
- org.apache.lucene.search.suggest.document.CompletionQuery
-
- org.apache.lucene.search.suggest.document.ContextQuery
-
- All Implemented Interfaces:
Accountable
public class ContextQuery extends CompletionQuery implements Accountable
ACompletionQuerythat matches documents specified by a wrappedCompletionQuerysupporting boosting and/or filtering by specified contexts.Use this query against
ContextSuggestFieldExample of using a
CompletionQuerywith boosted contexts:CompletionQuery completionQuery = ...; ContextQuery query = new ContextQuery(completionQuery); query.addContext("context1", 2); query.addContext("context2", 1);NOTE:
-
This query can be constructed with
PrefixCompletionQuery,RegexCompletionQueryorFuzzyCompletionQueryquery. -
To suggest across all contexts, use
addAllContexts(). When no context is added, the default behaviour is to suggest across all contexts. -
To apply the same boost to multiple contexts sharing the same prefix,
Use
addContext(CharSequence, float, boolean)with the common context prefix, boost and setexactto false. -
Using this query against a
SuggestField(not context enabled), would yield results ignoring any context filtering/boosting
-
-
Field Summary
Fields Modifier and Type Field Description protected CompletionQueryinnerQueryInner completion query
-
Constructor Summary
Constructors Constructor Description ContextQuery(CompletionQuery query)Constructs a context completion query that matches documents specified byquery.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddAllContexts()Add all contexts with a boost of 1fvoidaddContext(CharSequence context)Adds an exact context with default boost of 1voidaddContext(CharSequence context, float boost)Adds an exact context with boostvoidaddContext(CharSequence context, float boost, boolean exact)Adds a context with boost, setexactto false if the context is a prefix of any indexed contextsWeightcreateWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost)Expert: Constructs an appropriate Weight implementation for this query.booleanequals(Object o)Override and implement query instance equivalence properly in a subclass.inthashCode()Override and implement query hash code properly in a subclass.longramBytesUsed()Return the memory usage of this object in bytes.StringtoString(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.suggest.document.CompletionQuery
getField, getFilter, getTerm, rewrite
-
Methods inherited from class org.apache.lucene.search.Query
classHash, sameClassAs, toString
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.lucene.util.Accountable
getChildResources
-
-
-
-
Field Detail
-
innerQuery
protected CompletionQuery innerQuery
Inner completion query
-
-
Constructor Detail
-
ContextQuery
public ContextQuery(CompletionQuery query)
Constructs a context completion query that matches documents specified byquery.Use
addContext(CharSequence, float, boolean)to add context(s) with boost
-
-
Method Detail
-
addContext
public void addContext(CharSequence context)
Adds an exact context with default boost of 1
-
addContext
public void addContext(CharSequence context, float boost)
Adds an exact context with boost
-
addContext
public void addContext(CharSequence context, float boost, boolean exact)
Adds a context with boost, setexactto false if the context is a prefix of any indexed contexts
-
addAllContexts
public void addAllContexts()
Add all contexts with a boost of 1f
-
toString
public String toString(String field)
Description copied from class:QueryPrints a query to a string, withfieldassumed to be the default field and omitted.- Overrides:
toStringin classCompletionQuery
-
createWeight
public Weight createWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost) throws 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:
IOException
-
equals
public boolean equals(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)
-
visit
public void visit(QueryVisitor visitor)
Description copied from class:QueryRecurse through the query tree, visiting any child queries
-
ramBytesUsed
public long ramBytesUsed()
Description copied from interface:AccountableReturn the memory usage of this object in bytes. Negative values are illegal.- Specified by:
ramBytesUsedin interfaceAccountable
-
-