|
Berkeley DB version 4.2.52 |
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
java.lang.Object | +--com.sleepycat.bdb.bind.serial.TupleSerialKeyExtractor
A abstract key extractor that uses a tuple key and a serial value. This
class takes care of serializing and deserializing the value data, and
converting the key data to/from TupleInput and TupleOutput
objects. Its two abstract methods must be implemented by a concrete
subclass to extract and clear the index key using these objects.
| Constructor Summary | |
TupleSerialKeyExtractor(TupleFormat primaryKeyFormat,
SerialFormat valueFormat,
TupleFormat indexKeyFormat)
Creates a tuple-serial key extractor. |
|
| Method Summary | |
void |
clearIndexKey(DataBuffer valueData)
Clears the index key in a value buffer. |
abstract void |
clearIndexKey(Object valueInputOutput)
Clears the index key in the deserialized value data. |
void |
extractIndexKey(DataBuffer primaryKeyData,
DataBuffer valueData,
DataBuffer indexKeyData)
Extracts the index key data from primary key and value buffers. |
abstract void |
extractIndexKey(TupleInput primaryKeyInput,
Object valueInput,
TupleOutput indexKeyOutput)
Extracts the index key data from primary key tuple data and deserialized value data. |
DataFormat |
getIndexKeyFormat()
Returns the format of the index key data. |
DataFormat |
getPrimaryKeyFormat()
Returns the format of the primary key data or null if the index key data is not derived from the primary key data. |
DataFormat |
getValueFormat()
Returns the format of the value data or null if the index key data is not derived from the value data. |
| Methods inherited from class java.lang.Object |
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Constructor Detail |
public TupleSerialKeyExtractor(TupleFormat primaryKeyFormat,
SerialFormat valueFormat,
TupleFormat indexKeyFormat)
primaryKeyFormat - is the primary key format, or null if no
primary key data is used to construct the index key.valueFormat - is the value format, or null if no value data is
used to construct the index key.indexKeyFormat - is the index key format.| Method Detail |
public DataFormat getPrimaryKeyFormat()
KeyExtractorprimaryKeyData parameter
of KeyExtractor.extractIndexKey(com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer).
getPrimaryKeyFormat in interface KeyExtractorpublic DataFormat getValueFormat()
KeyExtractorvalueData parameter of KeyExtractor.extractIndexKey(com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer).
getValueFormat in interface KeyExtractorpublic DataFormat getIndexKeyFormat()
KeyExtractor
getIndexKeyFormat in interface KeyExtractor
public void extractIndexKey(DataBuffer primaryKeyData,
DataBuffer valueData,
DataBuffer indexKeyData)
throws IOException
KeyExtractor
extractIndexKey in interface KeyExtractorprimaryKeyData - is the source primary key data, or null if no
primary key data is used to construct the index key, in which case
KeyExtractor.getPrimaryKeyFormat() should also return null.valueData - is the source value data, or null if no value data is
used to construct the index key, in which case KeyExtractor.getValueFormat()
should also return null.indexKeyData - is the destination index key buffer. For index keys
which are optionally present, the buffer's length should be set to zero
to indicate that the key is not present or null.
IOException
public void clearIndexKey(DataBuffer valueData)
throws IOException
KeyExtractorForeignKeyIndex is configured with ForeignKeyIndex.ON_DELETE_CLEAR. It is never called
for index keys that are derived from primary key data, since in this
case ForeignKeyIndex.ON_DELETE_CLEAR is not
allowed.
clearIndexKey in interface KeyExtractorvalueData - is the source and destination value data. On entry
this contains the index key to be cleared. It should be changed by this
method such that KeyExtractor.extractIndexKey(com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer) will extract a null key (set
the buffer length to zero). Other data in the buffer should remain
unchanged.
IOException
public abstract void extractIndexKey(TupleInput primaryKeyInput,
Object valueInput,
TupleOutput indexKeyOutput)
throws IOException
primaryKeyInput - is the TupleInput for the primary key
data, or null if no primary key data is used to construct the index key.valueInput - is the deserialized value data, or null if no value
data is used to construct the index key.indexKeyOutput - is the destination index key tuple. For index
keys which are optionally present, no tuple data should be output to
indicate that the key is not present or null.
IOException
public abstract void clearIndexKey(Object valueInputOutput)
throws IOException
valueInputOutput - is the source and destination deserialized value
data. On entry this contains the index key to be cleared. It should be
changed by this method such that extractIndexKey(com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer) will extract a
null key (not output any tuple data). Other data in the value object
should remain unchanged.
IOException
|
Berkeley DB version 4.2.52 |
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||