public class SegmentReader extends IndexReader implements java.lang.Cloneable
NOTE: This API is new and still experimental (subject to change suddenly in the next release)
IndexReader.FieldOption| Modifier and Type | Field and Description |
|---|---|
protected boolean |
readOnly |
hasChanges| Constructor and Description |
|---|
SegmentReader() |
| Modifier and Type | Method and Description |
|---|---|
java.lang.Object |
clone()
Efficiently clones the IndexReader (sharing most
internal state).
|
IndexReader |
clone(boolean openReadOnly)
Clones the IndexReader and optionally changes readOnly.
|
protected BitVector |
cloneDeletedDocs(BitVector bv)
Clones the deleteDocs BitVector.
|
protected byte[] |
cloneNormBytes(byte[] bytes)
Clones the norm bytes.
|
Directory |
directory()
Returns the directory this index resides in.
|
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 docNum)
Implements deletion of the document numbered
docNum. |
protected void |
doSetNorm(int doc,
java.lang.String field,
byte value)
Implements setNorm in subclass.
|
protected void |
doUndeleteAll()
Implements actual undeleteAll() in subclass.
|
static SegmentReader |
get(boolean readOnly,
Directory dir,
SegmentInfo si,
int readBufferSize,
boolean doOpenStores,
int termInfosIndexDivisor) |
static SegmentReader |
get(boolean readOnly,
SegmentInfo si,
int termInfosIndexDivisor) |
static SegmentReader |
get(SegmentInfo si)
Deprecated.
|
java.lang.Object |
getDeletesCacheKey()
Expert.
|
java.lang.Object |
getFieldCacheKey()
Expert
|
java.util.Collection |
getFieldNames(IndexReader.FieldOption fieldOption)
Get a list of unique field names that exist in this index and have the specified
field option information.
|
protected byte[] |
getNorms(java.lang.String field) |
java.lang.String |
getSegmentName()
Return the name of the segment this reader is reading.
|
TermFreqVector |
getTermFreqVector(int docNumber,
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 docNumber)
Return an array of term frequency vectors for the specified document.
|
int |
getTermInfosIndexDivisor()
For IndexReader implementations that use
TermInfosReader to read terms, this returns the
current indexDivisor as specified when the reader was
opened.
|
long |
getUniqueTermCount()
Returns the number of unique terms (across all fields)
in this reader.
|
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 |
isDeleted(int n)
Returns true if document n has been deleted
|
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[] bytes,
int offset)
Read norms into a pre-allocated array.
|
int |
numDocs()
Returns the number of documents in this index.
|
TermDocs |
termDocs()
Returns an unpositioned
TermDocs enumerator. |
TermDocs |
termDocs(Term term)
Returns an enumeration of all the documents which contain
term. |
TermPositions |
termPositions()
Returns an unpositioned
TermPositions enumerator. |
TermEnum |
terms()
Returns an enumeration of all the terms in the index.
|
TermEnum |
terms(Term t)
Returns an enumeration of all terms starting at a given term.
|
acquireWriteLock, close, commit, commit, decRef, deleteDocument, deleteDocuments, document, ensureOpen, flush, flush, getCommitUserData, getCommitUserData, getCurrentVersion, getCurrentVersion, getCurrentVersion, getDisableFakeNorms, getIndexCommit, getRefCount, getSequentialSubReaders, getVersion, incRef, indexExists, indexExists, indexExists, isCurrent, isLocked, isLocked, isOptimized, lastModified, lastModified, lastModified, listCommits, main, numDeletedDocs, open, open, open, open, open, open, open, open, open, open, open, open, open, open, reopen, reopen, reopen, setDisableFakeNorms, setNorm, setNorm, setTermInfosIndexDivisor, termPositions, undeleteAll, unlockpublic static SegmentReader get(SegmentInfo si) throws CorruptIndexException, java.io.IOException
CorruptIndexException - if the index is corruptjava.io.IOException - if there is a low-level IO errorpublic static SegmentReader get(boolean readOnly, SegmentInfo si, int termInfosIndexDivisor) throws CorruptIndexException, java.io.IOException
CorruptIndexException - if the index is corruptjava.io.IOException - if there is a low-level IO errorpublic static SegmentReader get(boolean readOnly, Directory dir, SegmentInfo si, int readBufferSize, boolean doOpenStores, int termInfosIndexDivisor) throws CorruptIndexException, java.io.IOException
CorruptIndexException - if the index is corruptjava.io.IOException - if there is a low-level IO errorprotected byte[] cloneNormBytes(byte[] bytes)
bytes - Byte array to cloneprotected BitVector cloneDeletedDocs(BitVector bv)
bv - BitVector to clonepublic final java.lang.Object clone()
IndexReaderOn cloning a reader with pending changes (deletions, norms), the original reader transfers its write lock to the cloned reader. This means only the cloned reader may make further changes to the index, and commit the changes to the index on close, but the old reader still reflects all changes made up until it was cloned.
Like IndexReader.reopen(), it's safe to make changes to
either the original or the cloned reader: all shared
mutable state obeys "copy on write" semantics to ensure
the changes are not seen by other readers.
clone in class IndexReaderpublic final IndexReader clone(boolean openReadOnly) throws CorruptIndexException, java.io.IOException
IndexReaderclone in class IndexReaderCorruptIndexException - if the index is corruptjava.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 boolean hasDeletions()
IndexReaderhasDeletions in class IndexReaderprotected void doDelete(int docNum)
IndexReaderdocNum.
Applications should call IndexReader.deleteDocument(int) or IndexReader.deleteDocuments(Term).doDelete in class IndexReaderprotected void doUndeleteAll()
IndexReaderdoUndeleteAll in class IndexReaderpublic TermEnum terms()
IndexReaderTermEnum.next() must be called
on the resulting enumeration before calling other methods such as
TermEnum.term().terms in class IndexReaderpublic TermEnum terms(Term t) throws java.io.IOException
IndexReaderterms in class IndexReaderjava.io.IOException - if there is a low-level IO errorpublic 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 TermDocs termDocs(Term term) throws java.io.IOException
IndexReaderterm. For each document, the document number, the frequency of
the term in that document is also provided, for use in
search scoring. If term is null, then all non-deleted
docs are returned with freq=1.
Thus, this method implements the mapping:
The enumeration is ordered by document number. Each document number is greater than all that precede it in the enumeration.
termDocs 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 errorpublic int docFreq(Term t) throws java.io.IOException
IndexReadert.docFreq in class IndexReaderjava.io.IOException - if there is a low-level IO errorpublic int numDocs()
IndexReadernumDocs in class IndexReaderpublic int maxDoc()
IndexReadermaxDoc in class IndexReaderpublic java.util.Collection getFieldNames(IndexReader.FieldOption fieldOption)
IndexReadergetFieldNames in class IndexReaderfieldOption - specifies which field option should be available for the returned fieldsIndexReader.getFieldNames(org.apache.lucene.index.IndexReader.FieldOption)public boolean hasNorms(java.lang.String field)
IndexReaderhasNorms in class IndexReaderprotected byte[] getNorms(java.lang.String field)
throws java.io.IOException
java.io.IOExceptionpublic byte[] norms(java.lang.String field)
throws java.io.IOException
IndexReadernorms in class IndexReaderjava.io.IOExceptionAbstractField.setBoost(float)protected void doSetNorm(int doc,
java.lang.String field,
byte value)
throws java.io.IOException
IndexReaderdoSetNorm in class IndexReaderjava.io.IOExceptionpublic void norms(java.lang.String field,
byte[] bytes,
int offset)
throws java.io.IOException
norms in class IndexReaderjava.io.IOExceptionAbstractField.setBoost(float)public TermFreqVector getTermFreqVector(int docNumber, java.lang.String field) throws java.io.IOException
getTermFreqVector in class IndexReaderdocNumber - document for which the term frequency vector is returnedfield - field for which the term frequency vector is returned.java.io.IOExceptionField.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 TermFreqVector[] getTermFreqVectors(int docNumber) throws java.io.IOException
getTermFreqVectors in class IndexReaderdocNumber - document for which term frequency vectors are returnedjava.io.IOExceptionField.TermVectorpublic java.lang.String getSegmentName()
public Directory directory()
directory in class IndexReaderpublic final java.lang.Object getFieldCacheKey()
IndexReadergetFieldCacheKey in class IndexReaderpublic java.lang.Object getDeletesCacheKey()
IndexReadergetDeletesCacheKey in class IndexReaderpublic long getUniqueTermCount()
IndexReadergetUniqueTermCount in class IndexReaderpublic int getTermInfosIndexDivisor()
IndexReaderFor IndexReader implementations that use TermInfosReader to read terms, this returns the current indexDivisor as specified when the reader was opened.
getTermInfosIndexDivisor in class IndexReaderCopyright © 2000-2016 Apache Software Foundation. All Rights Reserved.