public abstract class AtomicReader extends IndexReader
AtomicReader is an abstract class, providing an interface for accessing an
index. Search of an index is done entirely through this abstract interface,
so that any subclass which implements it is searchable. IndexReaders implemented
by this subclass do not consist of several sub-readers,
they are atomic. They support retrieval of stored fields, doc values, terms,
and postings.
For efficiency, in this API documents are often referred to via document numbers, non-negative integers which each name a unique document in the index. These document numbers are ephemeral -- they may change as documents are added to and deleted from an index. Clients should thus not rely on a given document having the same number between sessions.
NOTE: IndexReader 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
IndexReader instance; use your own
(non-Lucene) objects instead.
IndexReader.ReaderClosedListener| Modifier | Constructor and Description |
|---|---|
protected |
AtomicReader() |
| Modifier and Type | Method and Description |
|---|---|
int |
docFreq(String field,
BytesRef term)
Returns the number of documents containing the
term. |
abstract DocValues |
docValues(String field)
Returns
DocValues for this field. |
abstract Fields |
fields()
Returns
Fields for this reader. |
abstract FieldInfos |
getFieldInfos()
Get the
FieldInfos describing all fields in
this reader. |
abstract Bits |
getLiveDocs()
Returns the
Bits representing live (not
deleted) docs. |
AtomicReaderContext |
getTopReaderContext()
Expert: Returns a the root
IndexReaderContext for this
IndexReader's sub-reader tree. |
long |
getUniqueTermCount()
Returns the number of unique terms (across all fields)
in this reader.
|
boolean |
hasNorms(String field)
Deprecated.
(4.0) use
getFieldInfos() and check FieldInfo.hasNorms()
for the field instead. |
abstract DocValues |
normValues(String field)
Returns
DocValues for this field's normalization values. |
DocsEnum |
termDocsEnum(Bits liveDocs,
String field,
BytesRef term)
Returns
DocsEnum for the specified field &
term. |
DocsEnum |
termDocsEnum(Bits liveDocs,
String field,
BytesRef term,
int flags)
Returns
DocsEnum for the specified field &
term, with control over whether freqs are required. |
DocsAndPositionsEnum |
termPositionsEnum(Bits liveDocs,
String field,
BytesRef term)
Returns
DocsAndPositionsEnum for the specified
field & term. |
DocsAndPositionsEnum |
termPositionsEnum(Bits liveDocs,
String field,
BytesRef term,
int flags)
Returns
DocsAndPositionsEnum for the specified
field & term, with control over whether offsets and payloads are
required. |
Terms |
terms(String field)
This may return null if the field does not exist.
|
long |
totalTermFreq(String field,
BytesRef term)
Returns the number of documents containing the term
t. |
addReaderClosedListener, close, decRef, docFreq, doClose, document, document, document, ensureOpen, equals, getCombinedCoreAndDeletesKey, getCoreCacheKey, getRefCount, getTermVector, getTermVectors, hasDeletions, hashCode, incRef, maxDoc, numDeletedDocs, numDocs, open, open, open, open, open, registerParentReader, removeReaderClosedListener, tryIncRefpublic final AtomicReaderContext getTopReaderContext()
IndexReaderIndexReaderContext for this
IndexReader's sub-reader tree. Iff this reader is composed of sub
readers ,ie. this reader being a composite reader, this method returns a
CompositeReaderContext holding the reader's direct children as well as a
view of the reader tree's atomic leaf contexts. All sub-
IndexReaderContext instances referenced from this readers top-level
context are private to this reader and are not shared with another context
tree. For example, IndexSearcher uses this API to drive searching by one
atomic leaf reader at a time. If this reader is not composed of child
readers, this method returns an AtomicReaderContext.
Note: Any of the sub-CompositeReaderContext instances reference from this
top-level context holds a null CompositeReaderContext.leaves()
reference. Only the top-level context maintains the convenience leaf-view
for performance reasons.
getTopReaderContext in class IndexReader@Deprecated public final boolean hasNorms(String field) throws IOException
IOExceptionpublic abstract Fields fields() throws IOException
Fields for this reader.
This method may return null if the reader has no
postings.IOExceptionpublic final int docFreq(String field, BytesRef term) throws IOException
IndexReaderterm. This method returns 0 if the term or
field does not exists. This method does not take into
account deleted documents that have not yet been merged
away.docFreq in class IndexReaderIOExceptionpublic final long totalTermFreq(String field, BytesRef term) throws IOException
t. This method returns 0 if the term or
field does not exists. This method does not take into
account deleted documents that have not yet been merged
away.IOExceptionpublic final Terms terms(String field) throws IOException
IOExceptionpublic final DocsEnum termDocsEnum(Bits liveDocs, String field, BytesRef term) throws IOException
DocsEnum for the specified field &
term. This will return null if either the field or
term does not exist.IOExceptionpublic final DocsEnum termDocsEnum(Bits liveDocs, String field, BytesRef term, int flags) throws IOException
DocsEnum for the specified field &
term, with control over whether freqs are required.
Some codecs may be able to optimize their
implementation when freqs are not required. This will
return null if the field or term does not
exist. See TermsEnum.docs(Bits,DocsEnum,int).IOExceptionpublic final DocsAndPositionsEnum termPositionsEnum(Bits liveDocs, String field, BytesRef term) throws IOException
DocsAndPositionsEnum for the specified
field & term. This will return null if the
field or term does not exist or positions weren't indexed.IOExceptiontermPositionsEnum(Bits, String, BytesRef, int)public final DocsAndPositionsEnum termPositionsEnum(Bits liveDocs, String field, BytesRef term, int flags) throws IOException
DocsAndPositionsEnum for the specified
field & term, with control over whether offsets and payloads are
required. Some codecs may be able to optimize their
implementation when offsets and/or payloads are not required.
This will return null if the field or term
does not exist or positions weren't indexed. See
TermsEnum.docsAndPositions(Bits,DocsAndPositionsEnum,int).IOExceptionpublic final long getUniqueTermCount()
throws IOException
IOExceptionpublic abstract DocValues docValues(String field) throws IOException
DocValues for this field.
This method may return null if the reader has no per-document
values stored.IOExceptionpublic abstract DocValues normValues(String field) throws IOException
DocValues for this field's normalization values.
This method may return null if the field has no norms.IOExceptionpublic abstract FieldInfos getFieldInfos()
FieldInfos describing all fields in
this reader.public abstract Bits getLiveDocs()
Bits representing live (not
deleted) docs. A set bit indicates the doc ID has not
been deleted. If this method returns null it means
there are no deleted documents (all documents are
live).
The returned instance has been safely published for
use by multiple threads without additional
synchronization.Copyright © 2000-2012 Apache Software Foundation. All Rights Reserved.