Class IDVersionPostingsFormat
java.lang.Object
org.apache.lucene.codecs.PostingsFormat
org.apache.lucene.sandbox.codecs.idversion.IDVersionPostingsFormat
- All Implemented Interfaces:
- NamedSPILoader.NamedSPI
A PostingsFormat optimized for primary-key (ID) fields that also record a version (long) for each
 ID, delivered as a payload created by 
longToBytes(long, org.apache.lucene.util.BytesRef) during indexing. At search time, the
 TermsEnum implementation IDVersionSegmentTermsEnum enables fast (using only the terms
 index when possible) lookup for whether a given ID was previously indexed with version > N
 (see IDVersionSegmentTermsEnum.seekExact(BytesRef,long).
 This is most effective if the app assigns monotonically increasing global version to each
 indexed doc. Then, during indexing, use IDVersionSegmentTermsEnum.seekExact(BytesRef,long) (along with LiveFieldValues) to
 decide whether the document you are about to index was already indexed with a higher version, and
 skip it if so.
 
The field is effectively indexed as DOCS_ONLY and the docID is pulsed into the terms dictionary, but the user must feed in the version as a payload on the first token.
NOTE: term vectors cannot be indexed with this field (not that you should really ever want to do this).
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final longversion must be <= this, because we encode with ZigZag.static final longversion must be >= this.Fields inherited from class org.apache.lucene.codecs.PostingsFormatEMPTY
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic longbytesToLong(BytesRef bytes) fieldsConsumer(SegmentWriteState state) fieldsProducer(SegmentReadState state) static voidlongToBytes(long v, BytesRef bytes) Methods inherited from class org.apache.lucene.codecs.PostingsFormatavailablePostingsFormats, forName, getName, reloadPostingsFormats, toString
- 
Field Details- 
MIN_VERSIONpublic static final long MIN_VERSIONversion must be >= this.- See Also:
 
- 
MAX_VERSIONpublic static final long MAX_VERSIONversion must be <= this, because we encode with ZigZag.- See Also:
 
 
- 
- 
Constructor Details- 
IDVersionPostingsFormatpublic IDVersionPostingsFormat()
- 
IDVersionPostingsFormatpublic IDVersionPostingsFormat(int minTermsInBlock, int maxTermsInBlock) 
 
- 
- 
Method Details- 
fieldsConsumer- Specified by:
- fieldsConsumerin class- PostingsFormat
- Throws:
- IOException
 
- 
fieldsProducer- Specified by:
- fieldsProducerin class- PostingsFormat
- Throws:
- IOException
 
- 
bytesToLong
- 
longToBytes
 
-