|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.lucene.search.Searcher
org.apache.lucene.search.IndexSearcher
public class IndexSearcher
Implements search over a single IndexReader.
Applications usually need only call the inherited Searcher.search(Query)
or Searcher.search(Query,Filter) methods. For performance reasons it is
recommended to open only one IndexSearcher and use it for all of your searches.
Note that you can only access Hits from an IndexSearcher as long as it is not yet closed, otherwise an IOException will be thrown.
| Constructor Summary | |
|---|---|
IndexSearcher(Directory directory)
Creates a searcher searching the index in the provided directory. |
|
IndexSearcher(IndexReader r)
Creates a searcher searching the provided index. |
|
IndexSearcher(String path)
Creates a searcher searching the index in the named directory. |
|
| Method Summary | |
|---|---|
void |
close()
Note that the underlying IndexReader is not closed, if IndexSearcher was constructed with IndexSearcher(IndexReader r). |
Document |
doc(int i)
Expert: Returns the stored fields of document i. |
Document |
doc(int i,
FieldSelector fieldSelector)
Get the Document at the nth position. |
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. |
IndexReader |
getIndexReader()
Return the IndexReader this searches. |
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 nDocs,
Sort sort)
Expert: Low-level search implementation with arbitrary sorting. |
| Methods inherited from class org.apache.lucene.search.Searcher |
|---|
createWeight, docFreqs, explain, getSimilarity, search, search, search, search, search, search, search, search, search, setSimilarity |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Constructor Detail |
|---|
public IndexSearcher(String path)
throws CorruptIndexException,
IOException
CorruptIndexException - if the index is corrupt
IOException - if there is a low-level IO error
public IndexSearcher(Directory directory)
throws CorruptIndexException,
IOException
CorruptIndexException - if the index is corrupt
IOException - if there is a low-level IO errorpublic IndexSearcher(IndexReader r)
| Method Detail |
|---|
public IndexReader getIndexReader()
IndexReader this searches.
public void close()
throws IOException
close in interface Searchableclose in class SearcherIOException
public 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 i)
throws CorruptIndexException,
IOException
Searchablei.
Called by HitCollector implementations.
doc in interface Searchabledoc in class SearcherCorruptIndexException - if the index is corrupt
IOException - if there is a low-level IO errorIndexReader.document(int)
public Document doc(int i,
FieldSelector fieldSelector)
throws CorruptIndexException,
IOException
SearchableDocument at the nth position. The FieldSelector
may be used to determine what Fields to load and how they should be loaded.
NOTE: If the underlying Reader (more specifically, the underlying FieldsReader) is closed before the lazy Field is
loaded an exception may be thrown. If you want the value of a lazy Field to be available after closing you must
explicitly load it or fetch the Document again with a new loader.
i - Get the document at the nth positionfieldSelector - The FieldSelector to use to determine what Fields should be loaded on the Document. May be null, in which case all Fields will be loaded.
Document at the nth position
CorruptIndexException - if the index is corrupt
IOException - if there is a low-level IO errorIndexReader.document(int, FieldSelector),
Fieldable,
FieldSelector,
SetBasedFieldSelector,
LoadFirstFieldSelector
public int maxDoc()
throws IOException
Searchable
maxDoc 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 SearcherIOException
public TopFieldDocs search(Weight weight,
Filter filter,
int nDocs,
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 SearcherIOException
public 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, used to permit documents to be collected.results - to receive hits
IOException
public Query rewrite(Query original)
throws IOException
Searchable
rewrite in interface Searchablerewrite in class SearcherIOException
public 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 SearcherIOException
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||