- All Implemented Interfaces:
Accountable
ConstantScoreQuery
over a BooleanQuery containing only BooleanClause.Occur.SHOULD clauses.
For instance in the following example, both q1 and q2 would 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 Scorer over this bit set.
NOTE: This query produces scores that are equal to its boost
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate static classprivate static class -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final long(package private) static final intprivate final Stringprivate final PrefixCodedTermsprivate final intFields inherited from interface org.apache.lucene.util.Accountable
NULL_ACCOUNTABLE -
Constructor Summary
ConstructorsConstructorDescriptionTermInSetQuery(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
Modifier and TypeMethodDescriptionprivate ByteRunAutomatoncreateWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost) Expert: Constructs an appropriate Weight implementation for this query.booleanOverride and implement query instance equivalence properly in a subclass.private booleanequalsTo(TermInSetQuery other) Returns nested resources of this class.Returns the terms wrapped in a PrefixCodedTerms.inthashCode()Override and implement query hash code properly in a subclass.longReturn the memory usage of this object in bytes.rewrite(IndexReader reader) Expert: called to re-write queries into primitive queries.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 queriesMethods inherited from class org.apache.lucene.search.Query
classHash, sameClassAs, toString
-
Field Details
-
BASE_RAM_BYTES_USED
private static final long BASE_RAM_BYTES_USED -
BOOLEAN_REWRITE_TERM_COUNT_THRESHOLD
static final int BOOLEAN_REWRITE_TERM_COUNT_THRESHOLD- See Also:
-
field
-
termData
-
termDataHashCode
private final int termDataHashCode
-
-
Constructor Details
-
TermInSetQuery
Creates a newTermInSetQueryfrom the given collection of terms. -
TermInSetQuery
Creates a newTermInSetQueryfrom the given array of terms.
-
-
Method Details
-
rewrite
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.Callers are expected to call
rewritemultiple times if necessary, until the rewritten query is the same as the original query.- Overrides:
rewritein classQuery- Throws:
IOException- See Also:
-
visit
Description copied from class:QueryRecurse through the query tree, visiting any child queries -
asByteRunAutomaton
-
equals
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.
-
equalsTo
-
hashCode
public int hashCode()Description copied from class:QueryOverride and implement query hash code properly in a subclass. This is required so thatQueryCacheworks properly. -
getTermData
Returns the terms wrapped in a PrefixCodedTerms. -
toString
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
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:
-
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
-