|
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()
KeyExtractor
primaryKeyData
parameter
of KeyExtractor.extractIndexKey(com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer)
.
getPrimaryKeyFormat
in interface KeyExtractor
public DataFormat getValueFormat()
KeyExtractor
valueData
parameter of KeyExtractor.extractIndexKey(com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer, com.sleepycat.bdb.bind.DataBuffer)
.
getValueFormat
in interface KeyExtractor
public DataFormat getIndexKeyFormat()
KeyExtractor
getIndexKeyFormat
in interface KeyExtractor
public void extractIndexKey(DataBuffer primaryKeyData, DataBuffer valueData, DataBuffer indexKeyData) throws IOException
KeyExtractor
extractIndexKey
in interface KeyExtractor
primaryKeyData
- 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
KeyExtractor
ForeignKeyIndex
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 KeyExtractor
valueData
- 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 |