Oracle® Call Interface Programmer's Guide 10g Release 1 (10.1) Part Number B10779-01 |
|
|
View PDF |
This section describes the maintaining context functions.
See Also:
For more information about using these functions, see Oracle Data Cartridge Developer's Guide |
This call is used to save a value (or address) for a particular duration.
sword OCIContextSetValue( dvoid *hndl, OCIError *err, OCIDuration duration, ub1 *key, ub1 keylen, dvoid *ctx_value );
The OCI environment or user session handle.
The error handle.
One of the following (a previously created user duration):
OCI_DURATION_STATEMENT
OCI_DURATION_SESSION
Unique key value.
Length of the key. Maximum is 64 bits.
Pointer that will be saved in the context.
The context value being stored must be allocated out of memory of duration greater than or equal to the duration being passed in. The key being passed in should be unique in this session. Trying to save a context value under the same key and duration again will result in overwriting the old context value with the new one. Typically, a client will allocate a structure, store its address in the context using this call, and get this address in a separate call using OCIContextGetValue()
. The (key, value) association can be explicitly removed by calling OCIContextClearValue()
or else it will go away at the end of the duration.
This call is used to return the value that is stored in the context associated with the given key (by calling OCIContextSetValue()
).
sword OCIContextGetValue( dvoid *hndl, OCIError *err, ub1 *key, ub1 keylen, dvoid **ctx_value );
The OCI environment or user session handle.
The error handle.
Unique key value.
Length of the key. Maximum is 64 bits.
Pointer to the value stored in the context (NULL
if no value was stored).
For ctx_value
: a pointer to a preallocated pointer for the stored context to be returned is required.
This call is used to remove the value that is stored in the context associated with the given key (by calling OCIContextSetValue()
).
sword OCIContextClearValue( dvoid *hndl, OCIError *err, ub1 *key, ub1 keylen );
The OCI environment or user session handle.
The error handle.
Unique key value.
Length of the key. Maximum is 64 bits.
An error is returned when a non-existent key is passed.
This call will return a unique, 4-byte value each time it is called.
sword OCIContextGenerateKey( dvoid *hndl, OCIError *err, ub4 *key );
The OCI environment or user session handle.
The error handle.
Unique key value.
Length of the key. Maximum is 64 bits.
This value is going to be unique for each session.