Class Searcher
- java.lang.Object
-
- org.apache.lucene.search.Searcher
-
- All Implemented Interfaces:
Closeable,AutoCloseable,Searchable
- Direct Known Subclasses:
IndexSearcher,MultiSearcher
@Deprecated public abstract class Searcher extends Object implements Searchable
Deprecated.In 4.0 this abstract class is removed/absorbed into IndexSearcherAn abstract base class for search implementations. Implements the main search methods.Note that you can only access hits from a Searcher as long as it is not yet closed, otherwise an IOException will be thrown.
-
-
Constructor Summary
Constructors Constructor Description Searcher()Deprecated.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description abstract voidclose()Deprecated.Frees resources associated with this Searcher.WeightcreateNormalizedWeight(Query query)Deprecated.Creates a normalized weight for a top-levelQuery.protected WeightcreateWeight(Query query)Deprecated.never ever use this method inWeightimplementations.abstract Documentdoc(int i)Deprecated.Returns the stored fields of documenti.abstract Documentdoc(int docid, FieldSelector fieldSelector)Deprecated.Get theDocumentat thenth position.abstract intdocFreq(Term term)Deprecated.Expert: Returns the number of documents containingterm.int[]docFreqs(Term[] terms)Deprecated.Expert: For each term in the terms array, calculates the number of documents containingterm.Explanationexplain(Query query, int doc)Deprecated.Returns an Explanation that describes howdocscored againstquery.abstract Explanationexplain(Weight weight, int doc)Deprecated.Expert: low-level implementation method Returns an Explanation that describes howdocscored againstweight.SimilaritygetSimilarity()Deprecated.Expert: Return the Similarity implementation used by this Searcher.abstract intmaxDoc()Deprecated.Expert: Returns one greater than the largest possible document number.abstract Queryrewrite(Query query)Deprecated.Expert: called to re-write queries into primitive queries.TopDocssearch(Query query, int n)Deprecated.Finds the topnhits forquery.TopFieldDocssearch(Query query, int n, Sort sort)Deprecated.Search implementation with arbitrary sorting and no filter.voidsearch(Query query, Collector results)Deprecated.Lower-level search API.TopDocssearch(Query query, Filter filter, int n)Deprecated.Finds the topnhits forquery, applyingfilterif non-null.TopFieldDocssearch(Query query, Filter filter, int n, Sort sort)Deprecated.Search implementation with arbitrary sorting.voidsearch(Query query, Filter filter, Collector results)Deprecated.Lower-level search API.abstract TopDocssearch(Weight weight, Filter filter, int n)Deprecated.Expert: Low-level search implementation.abstract TopFieldDocssearch(Weight weight, Filter filter, int n, Sort sort)Deprecated.Expert: Low-level search implementation with arbitrary sorting.abstract voidsearch(Weight weight, Filter filter, Collector results)Deprecated.Lower-level search API.voidsetSimilarity(Similarity similarity)Deprecated.Expert: Set the Similarity implementation used by this Searcher.
-
-
-
Method Detail
-
search
public TopFieldDocs search(Query query, Filter filter, int n, Sort sort) throws IOException
Deprecated.Search implementation with arbitrary sorting. Finds the topnhits forquery, applyingfilterif non-null, and sorting the hits by the criteria insort.NOTE: this does not compute scores by default; use
IndexSearcher.setDefaultFieldSortScoring(boolean, boolean)to enable scoring.
-
search
public TopFieldDocs search(Query query, int n, Sort sort) throws IOException
Deprecated.Search implementation with arbitrary sorting and no filter.- Parameters:
query- The query to search forn- Return only the top n resultssort- TheSortobject- Returns:
- The top docs, sorted according to the supplied
Sortinstance - Throws:
IOException
-
search
public void search(Query query, Collector results) throws IOException
Deprecated.Lower-level search API.Collector.collect(int)is called for every matching document.Applications should only use this if they need all of the matching documents. The high-level search API (
search(Query, int)) is usually more efficient, as it skips non-high-scoring hits.Note: The
scorepassed to this method is a raw score. In other words, the score will not necessarily be a float whose value is between 0 and 1.
-
search
public void search(Query query, Filter filter, Collector results) throws IOException
Deprecated.Lower-level search API.Collector.collect(int)is called for every matching 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 (
search(Query, Filter, int)) is usually more efficient, as it skips non-high-scoring hits.- Parameters:
query- to match documentsfilter- if non-null, used to permit documents to be collected.results- to receive hits- Throws:
BooleanQuery.TooManyClausesIOException
-
search
public TopDocs search(Query query, Filter filter, int n) throws IOException
Deprecated.Finds the topnhits forquery, applyingfilterif non-null.
-
search
public TopDocs search(Query query, int n) throws IOException
Deprecated.Finds the topnhits forquery.
-
explain
public Explanation explain(Query query, int doc) throws IOException
Deprecated.Returns an Explanation that describes howdocscored againstquery.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.
- Throws:
IOException
-
setSimilarity
public void setSimilarity(Similarity similarity)
Deprecated.Expert: Set the Similarity implementation used by this Searcher.- See Also:
Similarity.setDefault(Similarity)
-
getSimilarity
public Similarity getSimilarity()
Deprecated.Expert: Return the Similarity implementation used by this Searcher.This defaults to the current value of
Similarity.getDefault().
-
createNormalizedWeight
public Weight createNormalizedWeight(Query query) throws IOException
Deprecated.Creates a normalized weight for a top-levelQuery. The query is rewritten by this method andQuery.createWeight(org.apache.lucene.search.Searcher)called, afterwards theWeightis normalized. The returnedWeightcan then directly be used to get aScorer.- Throws:
IOException- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
-
createWeight
@Deprecated protected final Weight createWeight(Query query) throws IOException
Deprecated.never ever use this method inWeightimplementations. Subclasses of Searcher should usecreateNormalizedWeight(org.apache.lucene.search.Query), instead.Expert: Creates a normalized weight for a top-levelQuery. The query is rewritten by this method andQuery.createWeight(org.apache.lucene.search.Searcher)called, afterwards theWeightis normalized. The returnedWeightcan then directly be used to get aScorer.- Throws:
IOException
-
docFreqs
public int[] docFreqs(Term[] terms) throws IOException
Deprecated.Description copied from interface:SearchableExpert: For each term in the terms array, calculates the number of documents containingterm. Returns an array with these document frequencies. Used to minimize number of remote calls.- Specified by:
docFreqsin interfaceSearchable- Throws:
IOException
-
search
public abstract void search(Weight weight, Filter filter, Collector results) throws IOException
Deprecated.Description copied from interface:SearchableLower-level search API.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 (
search(Query,int)) is usually more efficient, as it skips non-high-scoring hits.- Specified by:
searchin interfaceSearchable- Parameters:
weight- to match documentsfilter- if non-null, used to permit documents to be collected.results- to receive hits- Throws:
IOException
-
close
public abstract void close() throws IOExceptionDeprecated.Description copied from interface:SearchableFrees resources associated with this Searcher. Be careful not to call this method while you are still using objects that reference this Searchable.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein interfaceSearchable- Throws:
IOException
-
docFreq
public abstract int docFreq(Term term) throws IOException
Deprecated.Description copied from interface:SearchableExpert: Returns the number of documents containingterm.- Specified by:
docFreqin interfaceSearchable- Throws:
IOException- See Also:
IndexReader.docFreq(Term)
-
maxDoc
public abstract int maxDoc() throws IOExceptionDeprecated.Description copied from interface:SearchableExpert: Returns one greater than the largest possible document number.- Specified by:
maxDocin interfaceSearchable- Throws:
IOException- See Also:
IndexReader.maxDoc()
-
search
public abstract TopDocs search(Weight weight, Filter filter, int n) throws IOException
Deprecated.Description copied from interface:SearchableExpert: Low-level search implementation. Finds the topnhits forquery, applyingfilterif non-null.Applications should usually call
search(Query,int)orsearch(Query,Filter,int)instead.- Specified by:
searchin interfaceSearchable- Throws:
IOException
-
doc
public abstract Document doc(int i) throws CorruptIndexException, IOException
Deprecated.Description copied from interface:SearchableReturns the stored fields of documenti.- Specified by:
docin interfaceSearchable- Throws:
CorruptIndexException- if the index is corruptIOException- if there is a low-level IO error- See Also:
IndexReader.document(int)
-
doc
public abstract Document doc(int docid, FieldSelector fieldSelector) throws CorruptIndexException, IOException
Deprecated.Description copied from interface:SearchableGet theDocumentat thenth position. TheFieldSelectormay be used to determine whatFields to load and how they should be loaded. NOTE: If the underlying Reader (more specifically, the underlyingFieldsReader) is closed before the lazyFieldis loaded an exception may be thrown. If you want the value of a lazyFieldto be available after closing you must explicitly load it or fetch the Document again with a new loader.- Specified by:
docin interfaceSearchable- Parameters:
docid- Get the document at thenth positionfieldSelector- TheFieldSelectorto use to determine what Fields should be loaded on the Document. May be null, in which case all Fields will be loaded.- Returns:
- The stored fields of the
Documentat the nth position - Throws:
CorruptIndexException- if the index is corruptIOException- if there is a low-level IO error- See Also:
IndexReader.document(int, FieldSelector),Fieldable,FieldSelector,SetBasedFieldSelector,LoadFirstFieldSelector
-
rewrite
public abstract Query rewrite(Query query) throws IOException
Deprecated.Description copied from interface:SearchableExpert: called to re-write queries into primitive queries.- Specified by:
rewritein interfaceSearchable- Throws:
IOException
-
explain
public abstract Explanation explain(Weight weight, int doc) throws IOException
Deprecated.Description copied from interface:SearchableExpert: low-level implementation method Returns an Explanation that describes howdocscored againstweight.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
explain(Query, int).- Specified by:
explainin interfaceSearchable- Throws:
IOException
-
search
public abstract TopFieldDocs search(Weight weight, Filter filter, int n, Sort sort) throws IOException
Deprecated.Description copied from interface:SearchableExpert: Low-level search implementation with arbitrary sorting. Finds the topnhits forquery, applyingfilterif non-null, and sorting the hits by the criteria insort.Applications should usually call
search(Query,Filter,int,Sort)instead.- Specified by:
searchin interfaceSearchable- Throws:
IOException
-
-