|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.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,int)
or Searcher.search(Query,Filter,int)
methods. For performance reasons it is
recommended to open only one IndexSearcher and use it for all of your searches.
NOTE: IndexSearcher
instances are completely
thread safe, meaning multiple threads can call any of its
methods, concurrently. If your application requires
external synchronization, you should not
synchronize on the IndexSearcher
instance;
use your own (non-Lucene) objects instead.
Field Summary | |
---|---|
protected int[] |
docStarts
|
protected IndexReader[] |
subReaders
|
Constructor Summary | |
---|---|
IndexSearcher(Directory path)
Creates a searcher searching the index in the named directory, with readOnly=true |
|
IndexSearcher(Directory path,
boolean readOnly)
Creates a searcher searching the index in the named directory. |
|
IndexSearcher(IndexReader r)
Creates a searcher searching the provided index. |
|
IndexSearcher(IndexReader reader,
IndexReader[] subReaders,
int[] docStarts)
Expert: directly specify the reader, subReaders and their docID starts. |
Method Summary | |
---|---|
void |
close()
Note that the underlying IndexReader is not closed, if IndexSearcher was constructed with IndexSearcher(IndexReader r). |
Document |
doc(int i)
Returns the stored fields of document i . |
Document |
doc(int i,
FieldSelector fieldSelector)
Get the Document at the n th 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 . |
protected void |
gatherSubReaders(List<IndexReader> allSubReaders,
IndexReader r)
|
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,
Collector collector)
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. |
TopFieldDocs |
search(Weight weight,
Filter filter,
int nDocs,
Sort sort,
boolean fillFields)
Just like search(Weight, Filter, int, Sort) , but you choose
whether or not the fields in the returned FieldDoc instances should
be set by specifying fillFields. |
void |
setDefaultFieldSortScoring(boolean doTrackScores,
boolean doMaxScore)
By default, no scores are computed when sorting by field (using Searcher.search(Query,Filter,int,Sort) ). |
Methods inherited from class org.apache.lucene.search.Searcher |
---|
createWeight, docFreqs, explain, getSimilarity, search, search, search, search, search, setSimilarity |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected IndexReader[] subReaders
protected int[] docStarts
Constructor Detail |
---|
public IndexSearcher(Directory path) throws CorruptIndexException, IOException
path
- directory where IndexReader will be opened
CorruptIndexException
- if the index is corrupt
IOException
- if there is a low-level IO errorpublic IndexSearcher(Directory path, boolean readOnly) throws CorruptIndexException, IOException
path
- directory where IndexReader will be openedreadOnly
- if true, the underlying IndexReader
will be opened readOnly
CorruptIndexException
- if the index is corrupt
IOException
- if there is a low-level IO errorpublic IndexSearcher(IndexReader r)
public IndexSearcher(IndexReader reader, IndexReader[] subReaders, int[] docStarts)
NOTE: This API is experimental and might change in incompatible ways in the next release.
Method Detail |
---|
protected void gatherSubReaders(List<IndexReader> allSubReaders, IndexReader r)
public IndexReader getIndexReader()
IndexReader
this searches.
public void close() throws IOException
close
in interface Closeable
close
in interface Searchable
close
in class Searcher
IOException
public int docFreq(Term term) throws IOException
Searchable
term
.
docFreq
in interface Searchable
docFreq
in class Searcher
IOException
IndexReader.docFreq(Term)
public Document doc(int i) throws CorruptIndexException, IOException
Searchable
i
.
doc
in interface Searchable
doc
in class Searcher
CorruptIndexException
- 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
Searchable
Document
at the n
th position. The FieldSelector
may be used to determine what Field
s 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.
doc
in interface Searchable
doc
in class Searcher
i
- Get the document at the n
th 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 Searchable
maxDoc
in class Searcher
IOException
IndexReader.maxDoc()
public TopDocs search(Weight weight, Filter filter, int nDocs) throws IOException
Searchable
n
hits for query
, applying filter
if non-null.
Applications should usually call Searcher.search(Query,int)
or
Searcher.search(Query,Filter,int)
instead.
search
in interface Searchable
search
in class Searcher
IOException
public TopFieldDocs search(Weight weight, Filter filter, int nDocs, Sort sort) throws IOException
Searchable
n
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,int,Sort)
instead.
search
in interface Searchable
search
in class Searcher
IOException
public TopFieldDocs search(Weight weight, Filter filter, int nDocs, Sort sort, boolean fillFields) throws IOException
search(Weight, Filter, int, Sort)
, but you choose
whether or not the fields in the returned FieldDoc
instances should
be set by specifying fillFields.
NOTE: this does not compute scores by default. If you
need scores, create a TopFieldCollector
instance by calling TopFieldCollector.create(org.apache.lucene.search.Sort, int, boolean, boolean, boolean, boolean)
and
then pass that to search(Weight, Filter,
Collector)
.
IOException
public void search(Weight weight, Filter filter, Collector collector) throws IOException
Searchable
Collector.collect(int)
is called for every document.
Collector-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,int)
) is
usually more efficient, as it skips non-high-scoring hits.
search
in interface Searchable
search
in class Searcher
weight
- to match documentsfilter
- if non-null, used to permit documents to be collected.collector
- to receive hits
IOException
public Query rewrite(Query original) throws IOException
Searchable
rewrite
in interface Searchable
rewrite
in class Searcher
IOException
public Explanation explain(Weight weight, int doc) throws IOException
Searchable
doc
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 Searchable
explain
in class Searcher
IOException
public void setDefaultFieldSortScoring(boolean doTrackScores, boolean doMaxScore)
Searcher.search(Query,Filter,int,Sort)
).
You can change that, per IndexSearcher instance, by
calling this method. Note that this will incur a CPU
cost.
doTrackScores
- If true, then scores are
returned for every matching document in TopFieldDocs
.doMaxScore
- If true, then the max score for all
matching docs is computed.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |