public class MultiReader extends IndexReader implements java.lang.Cloneable
IndexReader.FieldOption| Modifier and Type | Field and Description |
|---|---|
protected IndexReader[] |
subReaders |
hasChanges| Constructor and Description |
|---|
MultiReader(IndexReader[] subReaders)
Construct a MultiReader aggregating the named set of (sub)readers.
|
MultiReader(IndexReader[] subReaders,
boolean closeSubReaders)
Construct a MultiReader aggregating the named set of (sub)readers.
|
| Modifier and Type | Method and Description |
|---|---|
java.lang.Object |
clone()
Clones the subreaders.
|
int |
docFreq(Term t)
Returns the number of documents containing the term
t. |
protected void |
doClose()
Implements close.
|
protected void |
doCommit()
Deprecated.
|
protected void |
doCommit(java.util.Map commitUserData)
Implements commit.
|
Document |
document(int n,
FieldSelector fieldSelector)
Get the
Document at the n
th position. |
protected void |
doDelete(int n)
Implements deletion of the document numbered
docNum. |
protected IndexReader |
doReopen(boolean doClone)
If clone is true then we clone each of the subreaders
|
protected void |
doSetNorm(int n,
java.lang.String field,
byte value)
Implements setNorm in subclass.
|
protected void |
doUndeleteAll()
Implements actual undeleteAll() in subclass.
|
java.util.Collection |
getFieldNames(IndexReader.FieldOption fieldNames)
Get a list of unique field names that exist in this index and have the specified
field option information.
|
IndexReader[] |
getSequentialSubReaders()
Expert: returns the sequential sub readers that this
reader is logically composed of.
|
TermFreqVector |
getTermFreqVector(int n,
java.lang.String field)
Return a term frequency vector for the specified document and field.
|
void |
getTermFreqVector(int docNumber,
java.lang.String field,
TermVectorMapper mapper)
Load the Term Vector into a user-defined data structure instead of relying on the parallel arrays of
the
TermFreqVector. |
void |
getTermFreqVector(int docNumber,
TermVectorMapper mapper)
Map all the term vectors for all fields in a Document
|
TermFreqVector[] |
getTermFreqVectors(int n)
Return an array of term frequency vectors for the specified document.
|
long |
getVersion()
Not implemented.
|
boolean |
hasDeletions()
Returns true if any documents have been deleted
|
boolean |
hasNorms(java.lang.String field)
Returns true if there are norms stored for this field.
|
boolean |
isCurrent()
Checks recursively if all subreaders are up to date.
|
boolean |
isDeleted(int n)
Returns true if document n has been deleted
|
boolean |
isOptimized()
Checks is the index is optimized (if it has a single segment and
no deletions).
|
int |
maxDoc()
Returns one greater than the largest possible document number.
|
byte[] |
norms(java.lang.String field)
Returns the byte-encoded normalization factor for the named field of
every document.
|
void |
norms(java.lang.String field,
byte[] result,
int offset)
Reads the byte-encoded normalization factor for the named field of every
document.
|
int |
numDocs()
Returns the number of documents in this index.
|
IndexReader |
reopen()
Tries to reopen the subreaders.
|
TermDocs |
termDocs()
Returns an unpositioned
TermDocs enumerator. |
TermPositions |
termPositions()
Returns an unpositioned
TermPositions enumerator. |
TermEnum |
terms()
Returns an enumeration of all the terms in the index.
|
TermEnum |
terms(Term term)
Returns an enumeration of all terms starting at a given term.
|
acquireWriteLock, clone, close, commit, commit, decRef, deleteDocument, deleteDocuments, directory, document, ensureOpen, flush, flush, getCommitUserData, getCommitUserData, getCurrentVersion, getCurrentVersion, getCurrentVersion, getDeletesCacheKey, getDisableFakeNorms, getFieldCacheKey, getIndexCommit, getRefCount, getTermInfosIndexDivisor, getUniqueTermCount, incRef, indexExists, indexExists, indexExists, isLocked, isLocked, lastModified, lastModified, lastModified, listCommits, main, numDeletedDocs, open, open, open, open, open, open, open, open, open, open, open, open, open, open, reopen, reopen, setDisableFakeNorms, setNorm, setNorm, setTermInfosIndexDivisor, termDocs, termPositions, undeleteAll, unlockprotected IndexReader[] subReaders
public MultiReader(IndexReader[] subReaders)
Construct a MultiReader aggregating the named set of (sub)readers. Directory locking for delete, undeleteAll, and setNorm operations is left to the subreaders.
Note that all subreaders are closed if this Multireader is closed.
subReaders - set of (sub)readersjava.io.IOExceptionpublic MultiReader(IndexReader[] subReaders, boolean closeSubReaders)
Construct a MultiReader aggregating the named set of (sub)readers. Directory locking for delete, undeleteAll, and setNorm operations is left to the subreaders.
closeSubReaders - indicates whether the subreaders should be closed
when this MultiReader is closedsubReaders - set of (sub)readersjava.io.IOExceptionpublic IndexReader reopen() throws CorruptIndexException, java.io.IOException
A re-opened instance might share one or more subreaders with the old
instance. Index modification operations result in undefined behavior
when performed before the old instance is closed.
(see IndexReader.reopen()).
If subreaders are shared, then the reference count of those readers is increased to ensure that the subreaders remain open until the last referring reader is closed.
reopen in class IndexReaderCorruptIndexException - if the index is corruptjava.io.IOException - if there is a low-level IO errorpublic java.lang.Object clone()
IndexReader.clone()).
If subreaders are shared, then the reference count of those readers is increased to ensure that the subreaders remain open until the last referring reader is closed.
clone in class IndexReaderprotected IndexReader doReopen(boolean doClone) throws CorruptIndexException, java.io.IOException
doClone - CorruptIndexExceptionjava.io.IOExceptionpublic TermFreqVector[] getTermFreqVectors(int n) throws java.io.IOException
IndexReaderTermFreqVector
or of type TermPositionVector if
positions or offsets have been stored.getTermFreqVectors in class IndexReadern - document for which term frequency vectors are returnedjava.io.IOException - if index cannot be accessedField.TermVectorpublic TermFreqVector getTermFreqVector(int n, java.lang.String field) throws java.io.IOException
IndexReaderTermPositionVector is returned.getTermFreqVector in class IndexReadern - document for which the term frequency vector is returnedfield - field for which the term frequency vector is returned.java.io.IOException - if index cannot be accessedField.TermVectorpublic void getTermFreqVector(int docNumber,
java.lang.String field,
TermVectorMapper mapper)
throws java.io.IOException
IndexReaderTermFreqVector.getTermFreqVector in class IndexReaderdocNumber - The number of the document to load the vector forfield - The name of the field to loadmapper - The TermVectorMapper to process the vector. Must not be nulljava.io.IOException - if term vectors cannot be accessed or if they do not exist on the field and doc. specified.public void getTermFreqVector(int docNumber,
TermVectorMapper mapper)
throws java.io.IOException
IndexReadergetTermFreqVector in class IndexReaderdocNumber - The number of the document to load the vector formapper - The TermVectorMapper to process the vector. Must not be nulljava.io.IOException - if term vectors cannot be accessed or if they do not exist on the field and doc. specified.public boolean isOptimized()
IndexReaderisOptimized in class IndexReadertrue if the index is optimized; false otherwisepublic int numDocs()
IndexReadernumDocs in class IndexReaderpublic int maxDoc()
IndexReadermaxDoc in class IndexReaderpublic Document document(int n, FieldSelector fieldSelector) throws CorruptIndexException, java.io.IOException
IndexReaderDocument at the n
th position. The FieldSelector may be used to determine
what Fields to load and how they should
be loaded. NOTE: If this 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.
NOTE: for performance reasons, this method does not check if the
requested document is deleted, and therefore asking for a deleted document
may yield unspecified results. Usually this is not required, however you
can call IndexReader.isDeleted(int) with the requested document ID to verify
the document is not deleted.
document in class IndexReadern - 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 positionCorruptIndexException - if the index is corruptjava.io.IOException - if there is a low-level IO errorFieldable,
FieldSelector,
SetBasedFieldSelector,
LoadFirstFieldSelectorpublic boolean isDeleted(int n)
IndexReaderisDeleted in class IndexReaderpublic boolean hasDeletions()
IndexReaderhasDeletions in class IndexReaderprotected void doDelete(int n)
throws CorruptIndexException,
java.io.IOException
IndexReaderdocNum.
Applications should call IndexReader.deleteDocument(int) or IndexReader.deleteDocuments(Term).doDelete in class IndexReaderCorruptIndexExceptionjava.io.IOExceptionprotected void doUndeleteAll()
throws CorruptIndexException,
java.io.IOException
IndexReaderdoUndeleteAll in class IndexReaderCorruptIndexExceptionjava.io.IOExceptionpublic boolean hasNorms(java.lang.String field)
throws java.io.IOException
IndexReaderhasNorms in class IndexReaderjava.io.IOExceptionpublic byte[] norms(java.lang.String field)
throws java.io.IOException
IndexReadernorms in class IndexReaderjava.io.IOExceptionAbstractField.setBoost(float)public void norms(java.lang.String field,
byte[] result,
int offset)
throws java.io.IOException
IndexReadernorms in class IndexReaderjava.io.IOExceptionAbstractField.setBoost(float)protected void doSetNorm(int n,
java.lang.String field,
byte value)
throws CorruptIndexException,
java.io.IOException
IndexReaderdoSetNorm in class IndexReaderCorruptIndexExceptionjava.io.IOExceptionpublic TermEnum terms() throws java.io.IOException
IndexReaderTermEnum.next() must be called
on the resulting enumeration before calling other methods such as
TermEnum.term().terms in class IndexReaderjava.io.IOException - if there is a low-level IO errorpublic TermEnum terms(Term term) throws java.io.IOException
IndexReaderterms in class IndexReaderjava.io.IOException - if there is a low-level IO errorpublic int docFreq(Term t) throws java.io.IOException
IndexReadert.docFreq in class IndexReaderjava.io.IOException - if there is a low-level IO errorpublic TermDocs termDocs() throws java.io.IOException
IndexReaderTermDocs enumerator.termDocs in class IndexReaderjava.io.IOException - if there is a low-level IO errorpublic TermPositions termPositions() throws java.io.IOException
IndexReaderTermPositions enumerator.termPositions in class IndexReaderjava.io.IOException - if there is a low-level IO errorprotected void doCommit()
throws java.io.IOException
IndexReaderdoCommit in class IndexReaderjava.io.IOExceptionprotected void doCommit(java.util.Map commitUserData)
throws java.io.IOException
IndexReaderjava.io.IOExceptionprotected void doClose()
throws java.io.IOException
IndexReaderdoClose in class IndexReaderjava.io.IOExceptionpublic java.util.Collection getFieldNames(IndexReader.FieldOption fieldNames)
IndexReadergetFieldNames in class IndexReaderfieldNames - specifies which field option should be available for the returned fieldsIndexReader.FieldOptionpublic boolean isCurrent()
throws CorruptIndexException,
java.io.IOException
isCurrent in class IndexReaderCorruptIndexException - if the index is corruptjava.io.IOException - if there is a low-level IO errorpublic long getVersion()
getVersion in class IndexReaderjava.lang.UnsupportedOperationExceptionpublic IndexReader[] getSequentialSubReaders()
IndexReader
NOTE: You should not try using sub-readers returned by
this method to make any changes (setNorm, deleteDocument,
etc.). While this might succeed for one composite reader
(like MultiReader), it will most likely lead to index
corruption for other readers (like DirectoryReader obtained
through IndexReader.open(java.lang.String). Use the parent reader directly.
getSequentialSubReaders in class IndexReaderCopyright © 2000-2016 Apache Software Foundation. All Rights Reserved.