Package org.apache.lucene.search
Class TermInSetQuery
- java.lang.Object
-
- org.apache.lucene.search.Query
-
- org.apache.lucene.search.TermInSetQuery
-
- All Implemented Interfaces:
Accountable
public class TermInSetQuery extends Query implements Accountable
Specialization for a disjunction over many terms that behaves like aConstantScoreQueryover aBooleanQuerycontaining onlyBooleanClause.Occur.SHOULDclauses.For instance in the following example, both
q1andq2would yield the same scores:Query q1 = new TermInSetQuery("field", new BytesRef("foo"), new BytesRef("bar")); BooleanQuery bq = new BooleanQuery(); bq.add(new TermQuery(new Term("field", "foo")), Occur.SHOULD); bq.add(new TermQuery(new Term("field", "bar")), Occur.SHOULD); Query q2 = new ConstantScoreQuery(bq);When there are few terms, this query executes like a regular disjunction. However, when there are many terms, instead of merging iterators on the fly, it will populate a bit set with matching docs and return a
Scorerover this bit set.NOTE: This query produces scores that are equal to its boost
-
-
Field Summary
-
Fields inherited from interface org.apache.lucene.util.Accountable
NULL_ACCOUNTABLE
-
-
Constructor Summary
Constructors Constructor Description TermInSetQuery(String field, Collection<BytesRef> terms)Creates a newTermInSetQueryfrom the given collection of terms.TermInSetQuery(String field, BytesRef... terms)Creates a newTermInSetQueryfrom the given array of terms.
-
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(Object other)Override and implement query instance equivalence properly in a subclass.Collection<Accountable>getChildResources()Returns nested resources of this class.PrefixCodedTermsgetTermData()Returns the terms wrapped in a PrefixCodedTerms.inthashCode()Override and implement query hash code properly in a subclass.longramBytesUsed()Return the memory usage of this object in bytes.Queryrewrite(IndexReader reader)Expert: called to re-write queries into primitive queries.StringtoString(String defaultField)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, sameClassAs, toString
-
-
-
-
Constructor Detail
-
TermInSetQuery
public TermInSetQuery(String field, Collection<BytesRef> terms)
Creates a newTermInSetQueryfrom the given collection of terms.
-
TermInSetQuery
public TermInSetQuery(String field, BytesRef... terms)
Creates a newTermInSetQueryfrom the given array of terms.
-
-
Method Detail
-
rewrite
public Query rewrite(IndexReader reader) throws IOException
Description copied from class:QueryExpert: called to re-write queries into primitive queries. For example, a PrefixQuery will be rewritten into a BooleanQuery that consists of TermQuerys.- Overrides:
rewritein classQuery- Throws:
IOException
-
visit
public void visit(QueryVisitor visitor)
Description copied from class:QueryRecurse through the query tree, visiting any child queries
-
equals
public boolean equals(Object other)
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)
-
getTermData
public PrefixCodedTerms getTermData()
Returns the terms wrapped in a PrefixCodedTerms.
-
toString
public String toString(String defaultField)
Description copied from class:QueryPrints a query to a string, withfieldassumed to be the default field and omitted.
-
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
-
getChildResources
public Collection<Accountable> getChildResources()
Description copied from interface:AccountableReturns nested resources of this class. The result should be a point-in-time snapshot (to avoid race conditions).- Specified by:
getChildResourcesin interfaceAccountable- See Also:
Accountables
-
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
-
-