public class MultiCollector extends Collector
|Modifier and Type||Method and Description|
Called once for every document matching a query, with the unbased document number.
Called before collecting from each IndexReader.
Called before successive calls to
Collectors with a
MultiCollector. This method works as follows:
nullcollectors, so they are not used during search time.
null), it is returned.
MultiCollectorwhich wraps the non-
IllegalArgumentException- if either 0 collectors were input, or all collectors are
public boolean acceptsDocsOutOfOrder()
trueif this collector does not require the matching docIDs to be delivered in int sort order (smallest to largest) to
Most Lucene Query implementations will visit
matching docIDs in order. However, some queries
(currently limited to certain cases of
BooleanQuery) can achieve faster searching if the
Collector allows them to deliver the
docIDs out of order.
Many collectors don't mind getting docIDs out of
order, so it's important to return
public void collect(int doc) throws IOException
Note: This is called in an inner search loop. For good search performance,
implementations of this method should not call
IndexReader.document(int) on every hit.
Doing so can slow searches by an order of magnitude or more.
public void setNextReader(IndexReader reader, int o) throws IOException
Collector.collect(int)will correspond to reader. Add docBase to the current IndexReaders internal document id to re-base ids in
public void setScorer(Scorer s) throws IOException
Collector.collect(int). Implementations that need the score of the current document (passed-in to
Collector.collect(int)), should save the passed-in Scorer and call scorer.score() when needed.