Berkeley DB XML
version 2.5.16

com.sleepycat.bind.serial
Class TupleSerialMarshalledKeyCreator<D extends MarshalledTupleKeyEntity>

java.lang.Object
  extended by com.sleepycat.bind.tuple.TupleBase
      extended by com.sleepycat.bind.serial.TupleSerialKeyCreator<D>
          extended by com.sleepycat.bind.serial.TupleSerialMarshalledKeyCreator<D>
All Implemented Interfaces:
ForeignKeyNullifier, SecondaryKeyCreator

public class TupleSerialMarshalledKeyCreator<D extends MarshalledTupleKeyEntity>
extends TupleSerialKeyCreator<D>

A concrete key creator that works in conjunction with a TupleSerialMarshalledBinding. This key creator works by calling the methods of the MarshalledTupleKeyEntity interface to create and clear the index key fields.

See Also:
Class Evolution

Constructor Summary
TupleSerialMarshalledKeyCreator(TupleSerialMarshalledBinding<D> binding, String keyName)
          Creates a tuple-serial marshalled key creator.
 
Method Summary
 boolean createSecondaryKey(TupleInput primaryKeyInput, D dataInput, TupleOutput indexKeyOutput)
          Creates the index key entry from primary key tuple entry and deserialized data entry.
 D nullifyForeignKey(D dataInput)
          Clears the index key in the deserialized data entry.
 
Methods inherited from class com.sleepycat.bind.serial.TupleSerialKeyCreator
createSecondaryKey, nullifyForeignKey
 
Methods inherited from class com.sleepycat.bind.tuple.TupleBase
entryToInput, getTupleBufferSize, inputToEntry, newOutput, newOutput, outputToEntry, setTupleBufferSize
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

TupleSerialMarshalledKeyCreator

public TupleSerialMarshalledKeyCreator(TupleSerialMarshalledBinding<D> binding,
                                       String keyName)
Creates a tuple-serial marshalled key creator.

Parameters:
binding - is the binding used for the tuple-serial entity.
keyName - is the key name passed to the MarshalledTupleKeyEntity.marshalSecondaryKey(java.lang.String, com.sleepycat.bind.tuple.TupleOutput) method to identify the index key.
Method Detail

createSecondaryKey

public boolean createSecondaryKey(TupleInput primaryKeyInput,
                                  D dataInput,
                                  TupleOutput indexKeyOutput)
Description copied from class: TupleSerialKeyCreator
Creates the index key entry from primary key tuple entry and deserialized data entry.

Specified by:
createSecondaryKey in class TupleSerialKeyCreator<D extends MarshalledTupleKeyEntity>
Parameters:
primaryKeyInput - is the TupleInput for the primary key entry, or null if no primary key entry is used to construct the index key.
dataInput - is the deserialized data entry, or null if no data entry is used to construct the index key.
indexKeyOutput - is the destination index key tuple. For index keys which are optionally present, no tuple entry should be output to indicate that the key is not present or null.
Returns:
true if a key was created, or false to indicate that the key is not present.

nullifyForeignKey

public D nullifyForeignKey(D dataInput)
Description copied from class: TupleSerialKeyCreator
Clears the index key in the deserialized data entry.

On entry the data parameter contains the index key to be cleared. It should be changed by this method such that TupleSerialKeyCreator.createSecondaryKey(com.sleepycat.db.SecondaryDatabase, com.sleepycat.db.DatabaseEntry, com.sleepycat.db.DatabaseEntry, com.sleepycat.db.DatabaseEntry) will return false. Other fields in the data object should remain unchanged.

Overrides:
nullifyForeignKey in class TupleSerialKeyCreator<D extends MarshalledTupleKeyEntity>
Parameters:
dataInput - is the source and destination deserialized data entry.
Returns:
the destination data object, or null to indicate that the key is not present and no change is necessary. The data returned may be the same object passed as the data parameter or a newly created object.

Berkeley DB XML
version 2.5.16

Copyright (c) 1996,2009 Oracle. All rights reserved.