public class MultiSearcher extends Searcher
Searchables.
Applications usually need only call the inherited Searcher.search(Query)
or Searcher.search(Query,Filter) methods.
| Constructor and Description |
|---|
MultiSearcher(Searchable[] searchables)
Creates a searcher which searches searchables.
|
| Modifier and Type | Method and Description |
|---|---|
void |
close()
Frees resources associated with this Searcher.
|
protected Weight |
createWeight(Query original)
Create weight in multiple index scenario.
|
Document |
doc(int n)
Expert: Returns the stored fields of document
i. |
int |
docFreq(Term term)
Expert: Returns the number of documents containing
term. |
Explanation |
explain(Weight weight,
int doc)
Expert: low-level implementation method
Returns an Explanation that describes how
doc scored against
weight. |
Searchable[] |
getSearchables()
Return the array of
Searchables this searches. |
protected int[] |
getStarts() |
int |
maxDoc()
Expert: Returns one greater than the largest possible document number.
|
Query |
rewrite(Query original)
Expert: called to re-write queries into primitive queries.
|
void |
search(Weight weight,
Filter filter,
HitCollector results)
Lower-level search API.
|
TopDocs |
search(Weight weight,
Filter filter,
int nDocs)
Expert: Low-level search implementation.
|
TopFieldDocs |
search(Weight weight,
Filter filter,
int n,
Sort sort)
Expert: Low-level search implementation with arbitrary sorting.
|
int |
searcherIndex(int n)
Deprecated.
|
int |
subDoc(int n)
Returns the document number of document
n within its
sub-index. |
int |
subSearcher(int n)
Returns index of the searcher for document
n in the array
used to construct this searcher. |
public MultiSearcher(Searchable[] searchables) throws IOException
IOExceptionpublic Searchable[] getSearchables()
Searchables this searches.protected int[] getStarts()
public void close()
throws IOException
SearchableHits.close in interface Searchableclose in class SearcherIOExceptionpublic int docFreq(Term term) throws IOException
Searchableterm.
Called by search code to compute term weights.docFreq in interface SearchabledocFreq in class SearcherIOExceptionIndexReader.docFreq(Term)public Document doc(int n) throws IOException
Searchablei.
Called by HitCollector implementations.doc in interface Searchabledoc in class SearcherIOExceptionIndexReader.document(int)public int searcherIndex(int n)
subSearcher(int) instead.public int subSearcher(int n)
n in the array
used to construct this searcher.public int subDoc(int n)
n within its
sub-index.public int maxDoc()
throws IOException
SearchablemaxDoc in interface SearchablemaxDoc in class SearcherIOExceptionIndexReader.maxDoc()public TopDocs search(Weight weight, Filter filter, int nDocs) throws IOException
Searchablen
hits for query, applying filter if non-null.
Called by Hits.
Applications should usually call Searcher.search(Query) or
Searcher.search(Query,Filter) instead.
search in interface Searchablesearch in class SearcherIOExceptionpublic TopFieldDocs search(Weight weight, Filter filter, int n, Sort sort) throws IOException
Searchablen hits for query, applying
filter if non-null, and sorting the hits by the criteria in
sort.
Applications should usually call Searcher.search(Query,Filter,Sort) instead.
search in interface Searchablesearch in class SearcherIOExceptionpublic void search(Weight weight, Filter filter, HitCollector results) throws IOException
SearchableHitCollector.collect(int,float) is called for every non-zero
scoring document.
HitCollector-based access to remote indexes is discouraged.
Applications should only use this if they need all of the
matching documents. The high-level search API (Searcher.search(Query)) is usually more efficient, as it skips
non-high-scoring hits.
search in interface Searchablesearch in class Searcherweight - to match documentsfilter - if non-null, a bitset used to eliminate some documentsresults - to receive hitsIOExceptionpublic Query rewrite(Query original) throws IOException
Searchablerewrite in interface Searchablerewrite in class SearcherIOExceptionpublic Explanation explain(Weight weight, int doc) throws IOException
Searchabledoc scored against
weight.
This is intended to be used in developing Similarity implementations, and, for good performance, should not be displayed with every hit. Computing an explanation is as expensive as executing the query over the entire index.
Applications should call Searcher.explain(Query, int).
explain in interface Searchableexplain in class SearcherIOExceptionprotected Weight createWeight(Query original) throws IOException
createWeight in class SearcherIOExceptionCopyright © 2000-2013 Apache Software Foundation. All Rights Reserved.