public class MutableLeafData extends Object implements ILeafData
ILeafData
 record which operate by direct manipulation of the Java objects.
 
 Note: package private fields are used so that they may be directly accessed
 by the Leaf class.
| Constructor and Description | 
|---|
| MutableLeafData(int branchingFactor,
               boolean hasVersionTimestamps,
               boolean hasDeleteMarkers,
               boolean hasRawRecords)Create an empty data record with internal arrays dimensioned for the
 specified branching factor. | 
| MutableLeafData(int branchingFactor,
               ILeafData src)Copy ctor. | 
| Modifier and Type | Method and Description | 
|---|---|
| AbstractFixedByteArrayBuffer | data()The coded (aka compressed) data. | 
| boolean | getDeleteMarker(int index)Return  trueiff the entry at the specified index is marked
 as deleted. | 
| int | getKeyCount()Return the #of keys in the node or leaf. | 
| IRaba | getKeys()The object used to contain and manage the keys. | 
| long | getMaximumVersionTimestamp()The most recent tuple revision timestamp associated with any tuple
 spanned by this node or leaf. | 
| long | getMinimumVersionTimestamp()The earliest tuple revision timestamp associated with any tuple spanned
 by this node or leaf. | 
| long | getNextAddr()The address of the next leaf in key order,  0Lif it is known
 that there is no next leaf, and-1Lif either: (a) it is not
 known whether there is a next leaf; or (b) it is known but the address of
 that leaf is not known to the caller. | 
| long | getPriorAddr()The address of the previous leaf in key order,  0Lif it is
 known that there is no previous leaf, and-1Lif either: (a)
 it is not known whether there is a previous leaf; or (b) it is known but
 the address of that leaf is not known to the caller. | 
| long | getRawRecord(int index)Return the address of the raw record on the backing store of the value
 stored in the tuple having the given index -or-  IAddressManager.NULLif
 the value is the actualbyte[]value associated with the key
 in the leaf. | 
| int | getValueCount()The #of values in the leaf (this MUST be equal to the #of keys for a
 leaf). | 
| IRaba | getValues()Return the object storing the logical byte[][] containing the values for
 the leaf. | 
| long | getVersionTimestamp(int index)The version timestamp for the entry at the specified index. | 
| boolean | hasDeleteMarkers()Return  trueiff the leaf maintains delete markers. | 
| boolean | hasRawRecords()Return  trueiff the leaf promotes largebyte[]values to raw records on the backing store. | 
| boolean | hasVersionTimestamps()Return  trueiff the leaf maintains version timestamps. | 
| boolean | isCoded()No. | 
| boolean | isDoubleLinked()No - this class does not support double-linked leaves (only the
  IndexSegmentactually uses double-linked leaves). | 
| boolean | isLeaf()Always returns  true. | 
| boolean | isReadOnly()No - this is a mutable data record. | 
| protected boolean | rangeCheckTupleIndex(int index)Range check a tuple index. | 
public MutableLeafData(int branchingFactor,
               boolean hasVersionTimestamps,
               boolean hasDeleteMarkers,
               boolean hasRawRecords)
branchingFactor - The branching factor for the owning B+Tree.hasVersionTimestamps - true iff version timestamps will be maintained.hasDeleteMarkers - true iff delete markers will be maintained.hasRawRecords - true iff raw record markers will be maintained.public MutableLeafData(int branchingFactor,
               ILeafData src)
branchingFactor - The branching factor for the owning B+Tree.src - The source leaf.protected final boolean rangeCheckTupleIndex(int index)
index - The index of a tuple in [0:nkeys].trueIndexOutOfBoundsException - if the index is not in the legal range.public final boolean isReadOnly()
isReadOnly in interface IAbstractNodeDatapublic final boolean isCoded()
isCoded in interface IAbstractNodeDatapublic final AbstractFixedByteArrayBuffer data()
IAbstractNodeDatadata in interface IAbstractNodeDatadata in interface IDataRecordAccesspublic final long getVersionTimestamp(int index)
ILeafDatagetVersionTimestamp in interface ILeafDatapublic final long getMinimumVersionTimestamp()
IAbstractNodeDataLong.MAX_VALUE since the initial value of the minimum
 version timestamp is always the largest possible long integer.getMinimumVersionTimestamp in interface IAbstractNodeDatapublic final long getMaximumVersionTimestamp()
IAbstractNodeDataLong.MIN_VALUE since the initial value of the
 maximum version timestamp is always the smallest possible long integer.getMaximumVersionTimestamp in interface IAbstractNodeDatapublic final boolean getDeleteMarker(int index)
ILeafDatatrue iff the entry at the specified index is marked
 as deleted.getDeleteMarker in interface ILeafDatapublic final long getRawRecord(int index)
ILeafDataIAddressManager.NULL if
 the value is the actual byte[] value associated with the key
 in the leaf. When the value is the address of a raw record, the actual
 byte[] value should be read from the backing store using the
 decoded address.
 
 Raw record addresses are created transparently when a large
 byte[] is associated with a key in the leaf. They are
 materialized transparently when the tuple associated with the leaf is
 read. They are deleted when the tuple associated with the leaf is
 deleted.
 
 Note: Raw records are managed at the leaf, rather than the IRaba
 level, because there is not always a backing store associated with an
 IRaba object. This is similar to how deleted tuples are handled.
 However, IRabaCoders are responsible for coding the
 long address stored in the values raba.
 Raw records are only used for large byte[] values. Highly specialized
 IRabaCoders can avoid the potential for a conflict with their own
 coding scheme by ensuring that the index either will not promote large
 values to raw records or by refraining from inserting large values into
 the index.
getRawRecord in interface ILeafDataIAddressManager.NULLpublic final IRaba getValues()
ILeafData
 Note: When the leaf maintains raw records you MUST check whether or not
 the value was written onto a raw record before interpreting the data
 returned by IRaba.get(int). If the length of the value exceeded
 the configured maximum record length for the index, then the value was
 written onto a raw record on the backing store and IRaba.get(int)
 will return the encoded address of that record rather than its data.
getValues in interface ILeafDataILeafData.hasDeleteMarkers(), 
ILeafData.getDeleteMarker(int)public final IRaba getKeys()
IKeysDatapublic final boolean isLeaf()
true.isLeaf in interface IAbstractNodeDatapublic final int getValueCount()
ILeafDatagetValueCount in interface ILeafDatapublic final boolean hasRawRecords()
ILeafDatatrue iff the leaf promotes large byte[]
 values to raw records on the backing store.hasRawRecords in interface ILeafDatapublic final boolean hasDeleteMarkers()
ILeafDatatrue iff the leaf maintains delete markers.hasDeleteMarkers in interface ILeafDatapublic final boolean hasVersionTimestamps()
ILeafDatatrue iff the leaf maintains version timestamps.hasVersionTimestamps in interface IAbstractNodeDatahasVersionTimestamps in interface ILeafDatapublic final int getKeyCount()
IKeysDatankeys+1
 children. A leaf has nkeys keys and values. The maximum #of
 keys for a node is one less than the branching factor of the B+Tree. The
 maximum #of keys for a leaf is the branching factor of the B+Tree. For a
 hash bucket, this is the #of entries in the bucket.getKeyCount in interface IKeysDatapublic final boolean isDoubleLinked()
IndexSegment actually uses double-linked leaves).isDoubleLinked in interface ILeafDatapublic final long getNextAddr()
ILeafData0L if it is known
 that there is no next leaf, and -1L if either: (a) it is not
 known whether there is a next leaf; or (b) it is known but the address of
 that leaf is not known to the caller.getNextAddr in interface ILeafDatapublic final long getPriorAddr()
ILeafData0L if it is
 known that there is no previous leaf, and -1L if either: (a)
 it is not known whether there is a previous leaf; or (b) it is known but
 the address of that leaf is not known to the caller.getPriorAddr in interface ILeafDataCopyright © 2006–2019 SYSTAP, LLC DBA Blazegraph. All rights reserved.