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
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(AtomicReaderContext context) throws IOException
AtomicReaderContext. All doc ids in
Collector.collect(int)will correspond to
AtomicReaderContext.docBaseto the current
IndexReaderContext.reader()'s 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.
Copyright © 2000-2013 Apache Software Foundation. All Rights Reserved.