9.1. ODPI-C Connection Functions

Connection handles are used to represent connections to the database. These can be standalone connections created by calling the function dpiConn_create() or acquired from a session pool by calling the function dpiPool_acquireConnection(). They can be closed by calling the function dpiConn_close() or releasing the last reference to the connection by calling the function dpiConn_release(). Connection handles are used to create all handles other than session pools and context handles.

int dpiConn_addRef(dpiConn *conn)

Adds a reference to the connection. This is intended for situations where a reference to the connection needs to be maintained independently of the reference returned when the connection was created.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

The connection to which a reference is to be added. If the reference is NULL or invalid, an error is returned.

int dpiConn_breakExecution(dpiConn *conn)

Performs an immediate (asynchronous) termination of any currently executing function on the server associated with the connection.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection on which the break is to take place. If the reference is NULL or invalid, an error is returned.

int dpiConn_changePassword(dpiConn *conn, const char *userName, uint32_t userNameLength, const char *oldPassword, uint32_t oldPasswordLength, const char *newPassword, uint32_t newPasswordLength)

Changes the password of the specified user.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection on which the password is to be changed. If the reference is NULL or invalid, an error is returned.

userName

IN

The name of the user whose password is to be changed, as a byte string in the encoding used for CHAR data.

userNameLength

IN

The length of the user name parameter, in bytes.

oldPassword

IN

The old password of the user whose password is to be changed, as a byte string in the encoding used for CHAR data.

oldPasswordLength

IN

The length of the old password parameter, in bytes.

newPassword

IN

The new password of the user whose password is to be changed, as a byte string in the encoding used for CHAR data.

newPasswordLength

IN

The length of the new password parameter, in bytes.

int dpiConn_close(dpiConn *conn, dpiConnCloseMode mode, const char *tag, uint32_t tagLength)

Closes the connection and makes it unusable for further activity. Any open statements and LOBs associated with the connection will also be closed and made unusable for further activity.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection which is to be closed. If the reference is NULL or invalid, an error is returned.

mode

IN

One or more of the values from the enumeration dpiConnCloseMode, OR’ed together.

tag

IN

A byte string in the encoding used for CHAR data, indicating what tag should be set on the connection when it is released back to the pool. NULL is also acceptable when indicating that the tag should be cleared. This value is ignored unless the close mode includes the value DPI_MODE_CONN_CLOSE_RETAG.

tagLength

IN

The length of the tag parameter, in bytes, or 0 if the tag parameter is NULL.

int dpiConn_commit(dpiConn *conn)

Commits the current active transaction.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection which holds the transaction which is to be committed. If the reference is NULL or invalid, an error is returned.

int dpiConn_create(const dpiContext *context, const char *userName, uint32_t userNameLength, const char *password, uint32_t passwordLength, const char *connectString, uint32_t connectStringLength, dpiCommonCreateParams *commonParams, dpiConnCreateParams *createParams, dpiConn **conn)

Creates a standalone connection to a database or acquires a connection from a session pool and returns a reference to the connection.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure. If a failure occurs, the errorInfo structure is filled in with error information.

Parameter

Mode

Description

context

IN

The context handle created earlier using the function dpiContext_createWithParams(). If the handle is NULL or invalid, an error is returned.

userName

IN

The name of the user used for authenticating the user, as a byte string in the encoding used for CHAR data. NULL is also acceptable if external authentication is being requested or if credentials were specified when the pool was created.

userNameLength

IN

The length of the userName parameter, in bytes, or 0 if the userName parameter is NULL.

password

IN

The password to use for authenticating the user, as a byte string in the encoding used for CHAR data. NULL is also acceptable if external authentication is being requested or if credentials were specified when the pool was created.

passwordLength

IN

The length of the password parameter, in bytes, or 0 if the password parameter is NULL.

connectString

IN

The connect string identifying the database to which a connection is to be established, as a byte string in the encoding used for CHAR data. NULL is also acceptable for local connections (identified by the environment variable $ORACLE_SID) or when a connection is being acquired from a session pool. This value is ignored when a connection is being acquired from a session pool.

connectStringLength

IN

The length of the connectString parameter, in bytes, or 0 if the connectString parameter is NULL.

commonParams

IN

A pointer to a dpiCommonCreateParams structure which is used to specify context parameters for connection creation. NULL is also acceptable in which case all default parameters will be used when creating the connection. This value is ignored when acquiring a connection from a session pool.

createParams

IN

A pointer to a dpiConnCreateParams structure which is used to specify parameters for connection creation. NULL is also acceptable in which case all default parameters will be used when creating the connection. If the member pool is not NULL, a connection will be acquired from the pool (as if the function dpiPool_acquireConnection() had been called); otherwise, a standalone connection will be created.

conn

OUT

A pointer to a reference to the connection that is created. Call dpiConn_release() when the reference is no longer needed.

int dpiConn_deqObject(dpiConn *conn, const char *queueName, uint32_t queueNameLength, dpiDeqOptions *options, dpiMsgProps *props, dpiObject *payload, const char **msgId, uint32_t *msgIdLength)

Dequeues a message from a queue. This function is deprecated and will be removed in version 4. One of the functions dpiQueue_deqOne() or dpiQueue_deqMany() should be used instead.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the message is to be dequeued. If the reference is NULL or invalid, an error is returned.

queueName

IN

The name of the queue from which the message is to be dequeued, as a byte string in the encoding used for CHAR data.

queueNameLength

IN

The length of the queueName parameter, in bytes.

options

IN

A reference to the dequeue options that should be used when dequeuing the message from the queue.

props

IN

A reference to the message properties that will be populated with information from the message that is dequeued.

payload

IN

A reference to the object which will be populated with the message that is dequeued.

msgId

OUT

A pointer to a byte string which will be populated with the id of the message that is dequeued, or NULL if no message is available. If there is a message id, the pointer will remain valid until the next call to dpiConn_enqObject() or dpiConn_deqObject().

msgIdLength

OUT

A pointer to the length of the msgId parameter, or 0 if the msgId parameter is NULL.

int dpiConn_enqObject(dpiConn *conn, const char *queueName, uint32_t queueNameLength, dpiEnqOptions *options, dpiMsgProps *props, dpiObject *payload, const char **msgId, uint32_t *msgIdLength)

Enqueues a message to a queue. This function is deprecated and will be removed in version 4. One of the functions dpiQueue_enqOne() or dpiQueue_enqMany() should be used instead.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection to which the message is to be enqueued. If the reference is NULL or invalid, an error is returned.

queueName

IN

The name of the queue to which the message is to be enqueued, as a byte string in the encoding used for CHAR data.

queueNameLength

IN

The length of the queueName parameter, in bytes.

options

IN

A reference to the enqueue options that should be used when enqueuing the message to the queue.

props

IN

A reference to the message properties that will affect the message that is enqueued.

payload

IN

a reference to the object which will be enqueued.

msgId

OUT

A pointer to a byte string which will be populated with the id of the message that is enqueued upon successful completion of this function. The pointer will remain valid until the next call to dpiConn_enqObject() or dpiConn_deqObject().

msgIdLength

OUT

A pointer to the length of the msgId parameter which will be populated upon successful completion of this function.

int dpiConn_getCallTimeout(dpiConn *conn, uint32_t *value)

Returns the current call timeout (in milliseconds) used for round-trips to the database made with this connection. A value of 0 means that no timeouts will take place. This value can be set using the function dpiConn_setCallTimeout().

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the current call timeout is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the call timeout value, which will be populated upon successful completion of this function.

int dpiConn_getCurrentSchema(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the current schema that is being used by the connection.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the current schema is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the current schema, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held and the current schema is not changed by some means.

valueLength

OUT

A pointer to the length of the current schema, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getDbDomain(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the Oracle Database Domain name associated with the connection. This is the same value returned by the SQL expression SELECT value FROM V$PARAMETER WHERE NAME = 'db_domain'.

This function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the database domain name is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the database domain name, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held.

valueLength

OUT

A pointer to the length of the database domain name, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getDbName(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the Oracle Database name associated with the connection. This is the same value returned by the SQL expression SELECT NAME FROM V$DATABASE.

This function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the database name is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the database name, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held.

valueLength

OUT

A pointer to the length of the database name, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getEdition(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the edition that is being used by the connection.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the edition is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the edition, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held and the edition is not changed by some means.

valueLength

OUT

A pointer to the length of the edition, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getEncodingInfo(dpiConn *conn, dpiEncodingInfo *info)

Returns the encoding information used by the connection. This will be equivalent to the values passed when the standalone connection or session pool was created, or the values retrieved from the environment variables NLS_LANG and NLS_NCHAR.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection whose encoding information is to be retrieved. If the reference is NULL or invalid, an error is returned.

info

OUT

A pointer to a dpiEncodingInfo structure which will be populated with the encoding information used by the connection.

int dpiConn_getExternalName(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the external name that is being used by the connection. This value is used when logging distributed transactions.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the external name is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the external name, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held and the external name is not changed by some means.

valueLength

OUT

A pointer to the length of the external name, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getHandle(dpiConn *conn, void **handle)

Returns the OCI service context handle in use by the connection.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection whose service context handle is to be retrieved. If the reference is NULL or invalid, an error is returned.

handle

OUT

A pointer which will be populated with the service context handle of the connection upon successful completion of the function. This handle can be used within OCI calls independently of the library, but care must be taken not to cause problems due to shared use.

int dpiConn_getInstanceName(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the Oracle Database instance name associated with the connection. This is the same value returned by the SQL expression sys_context('userenv', 'instance_name').

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the instance name is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the instance name, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held.

valueLength

OUT

A pointer to the length of the instance name, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getInternalName(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the internal name that is being used by the connection. This value is used when logging distributed transactions.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the internal name is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the internal name, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held and the internal name is not changed by some means.

valueLength

OUT

A pointer to the length of the internal name, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getIsHealthy(dpiConn *conn, int *isHealthy)

Checks if a connection is usable. Connections may become unusable in several cases, such as if the network socket is broken, if an Oracle error indicates the connection is unusable or after receiving a planned down notification from the database.

This function is best used before starting a new database request on an existing standalone connection. Pooled connections internally perform this check before returning a connection to the application.

Avoid using this function when database requests are in progress.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure. If DPI_FAILURE is returned, the connection should be not be used by the application and a new connection should be established instead.

This function performs a local check. To fully check a connection’s health, use dpiConn_ping().

Parameter

Mode

Description

conn

IN

A reference to the connection for which the status is to be checked. If the reference is NULL or invalid, an error is returned.

isHealthy

OUT

A pointer to an integer defining whether the connection is healthy (1) or not (0), which will be populated upon successful completion of this function.

int dpiConn_getLTXID(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the logical transaction id for the connection. This value is used in Transaction Guard to determine if the last failed call was completed and if the transaction was committed using the procedure call dbms_app_cont.get_ltxid_outcome().

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the logical transaction id is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the logical transaction id, as a byte string, which will be populated upon successful completion of this function. The bytes returned will remain valid as long as a reference to the connection is held and the logical transaction id is not changed by some means.

valueLength

OUT

A pointer to the length of the logical transaction id, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getMaxOpenCursors(dpiConn *conn, uint32_t *maxOpenCursors)

Returns the maximum number of cursors that can be opened. This is the same value returned by the SQL expression SELECT VALUE FROM V$PARAMETER WHERE NAME = 'open_cursors'.

This function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the maximum number of open cursors is to be retrieved. If the reference is NULL or invalid an error is returned.

maxOpenCursors

OUT

A pointer of type uint32_t, which will be populated upon successful completion of this function.

int dpiConn_getObjectType(dpiConn *conn, const char *name, uint32_t nameLength, dpiObjectType **objType)

Looks up an object type by name in the database and returns a reference to it. The reference should be released as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection which contains the object type to look up. If the reference is NULL or invalid, an error is returned.

name

IN

The name of the object type to lookup, as a byte string in the encoding used for CHAR data.

nameLength

IN

The length of the name parameter, in bytes.

objType

OUT

A pointer to a reference to the object type, which will be populated upon successfully locating the object type.

int dpiConn_getOciAttr(dpiConn *conn, uint32_t handleType, uint32_t attribute, dpiDataBuffer *value, uint32_t *valueLength)

Returns the value of an OCI attribute. This is intended solely for testing attributes that are not otherwise supported by ODPI-C and should not be used for any other purpose. Use only as directed by Oracle.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the OCI attribute is to be returned. If the reference is NULL or invalid, an error is returned.

handleType

IN

The type of OCI handle that is to be used. This should be one of 3 (service context handle), 8 (server handle) or 9 (session handle).

attribute

IN

The attribute to acquire.

value

OUT

A data buffer which will be populated with the value of the OCI attribute upon successfully completing this function.

valueLength

OUT

The length of the attribute which will be populated upon succesfully completing this function.

int dpiConn_getServerVersion(dpiConn *conn, const char **releaseString, uint32_t *releaseStringLength, dpiVersionInfo *versionInfo)

Returns the version information of the Oracle Database to which the connection has been made.

Note

If you connect to Oracle Database 18 or later with Client libraries 12.2 or earlier that you will only receive the base version (such as 18.0.0.0.0) instead of the full version (such as 18.3.0.0.0).

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the server version information is to be retrieved. If the reference is NULL or invalid, an error is returned.

releaseString

OUT

A pointer to the release string which will be populated when this function returns successfully. The string remains valid as long as a reference is held to the connection. This parameter may also be NULL. In Oracle Client 20.3 and higher, using NULL will eliminate the need for a round-trip to the server.

releaseStringLength

OUT

A pointer to the length of the release string which will be populated when this function returns successfully. This parameter may also be NULL.

versionInfo

OUT

A pointer to a dpiVersionInfo structure which will be populated with the version information of the Oracle Database to which the connection has been made.

int dpiConn_getServiceName(dpiConn *conn, const char **value, uint32_t *valueLength)

Returns the Oracle Database service name associated with the connection. This is the same value returned by the SQL expression SELECT SYS_CONTEXT('USERENV', 'SERVICE_NAME') FROM DUAL.

This function returns DPI_SCCUESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the service name is to be retrieved. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the service name, as a byte string in the encoding used for CHAR data, which will be populated upon successful completion of this function. The string returned will remain valid as long as a reference to the connection is held.

valueLength

OUT

A pointer to the length of the service name, in bytes, which will be populated upon successful completion of this function.

int dpiConn_getSodaDb(dpiConn *conn, dpiSodaDb **db)

Return a reference to a SODA database which can be used to create, open and drop collections. The connection that is passed should remain open while SODA operations are being performed. If the connection is closed an error will take place when the next SODA operation is attempted.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection to use for accessing the SODA database.

db

OUT

A pointer to a reference to a newly allocated SODA database if the function completes successfully. The function dpiSodaDb_release() should be used when the database is no longer required.

int dpiConn_getStmtCacheSize(dpiConn *conn, uint32_t *cacheSize)

Returns the size of the statement cache, in number of statements.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection from which the size of the statement cache is to be retrieved. If the reference is NULL or invalid, an error is returned.

cacheSize

OUT

A pointer to the size of the statement cache, which will be populated upon successful completion of this function.

int dpiConn_getTransactionInProgress(dpiConn *conn, const int *txnInProgress)

Returns whether a transaction is in progress or not.

This function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the presence of a transaction should be detected. If the reference is NULL or invalid, an error is returned.

value

OUT

A pointer to the transaction in progress, which will be populated with 0 (no transaction) or 1 (a transaction is in progress) upon successful completion of this function.

int dpiConn_newDeqOptions(dpiConn *conn, dpiDeqOptions **options)

Returns a reference to a new set of dequeue options, used in dequeuing objects from a queue. The reference should be released as soon as it is no longer needed. This function is deprecated and will be removed in version 4. The function dpiQueue_getDeqOptions() should be used instead.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the dequeue is going to take place. If the reference is NULL or invalid, an error is returned.

options

OUT

A pointer to a reference to the dequeue options that is created by this function.

int dpiConn_newEnqOptions(dpiConn *conn, dpiEnqOptions **options)

Returns a reference to a new set of enqueue options, used in enqueuing objects into a queue. The reference should be released as soon as it is no longer needed. This function is deprecated and will be removed in version 4. The function dpiQueue_getEnqOptions() should be used instead.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the enqueue is going to take place. If the reference is NULL or invalid, an error is returned.

options

OUT

A pointer to a reference to the enqueue options that is created by this function.

int dpiConn_newJson(dpiConn *conn, dpiJson **json)

Returns a reference to a new JSON object. This object can be used as the payload in a message enqueued in a JSON queue, or as the value for a variable. The reference should be released by calling dpiJson_release() as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the JSON object is going to be used. If the reference is NULL or invalid, an error is returned.

json

OUT

A pointer to a reference to the JSON object that is created by this function.

int dpiConn_newJsonQueue(dpiConn *conn, const char *name, uint32_t nameLength, dpiQueue **queue)

Returns a reference to a new queue which enqueues and dequeues messages from Advanced Queueing (AQ) with a JSON payload. The reference should be released by calling dpiQueue_release() as soon as it is no longer needed. For queues with RAW or Database Object payloads, use the method dpiConn_newQueue() instead.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which messages are to be dequeued or enqueued. If the reference is NULL or invalid, an error is returned.

name

IN

The name of the queue, as a byte string in the encoding used for CHAR data. Note that UTF-16 encodings are not currently supported by AQ.

nameLength

IN

The length of the name parameter, in bytes.

queue

OUT

A reference to the newly created queue which will be populated upon successful completion of this function. The reference should be released by calling dpiQueue_release() as soon as it is no longer needed.

int dpiConn_newMsgProps(dpiConn *conn, dpiMsgProps **props)

Returns a reference to a new set of message properties, used in enqueuing and dequeuing objects in a queue. The reference should be released as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the enqueue or dequeue is going to take place. If the reference is NULL or invalid, an error is returned.

props

OUT

A pointer to a reference to the message properties that is created by this function.

int dpiConn_newQueue(dpiConn *conn, const char *name, uint32_t nameLength, dpiObjectType *payloadType, dpiQueue **queue)

Returns a reference to a new queue which may be used to enqueue and dequeue messages from Advanced Queuing (AQ) queues. The reference should be released by calling dpiQueue_release() as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which messages are to be dequeued or enqueued. If the reference is NULL or invalid, an error is returned.

name

IN

The name of the queue, as a byte string in the encoding used for CHAR data. Note that UTF-16 encodings are not currently supported by AQ.

nameLength

IN

The length of the name parameter, in bytes.

payloadType

IN

A reference to the object type which will be used for the payload of messages that dequeued and enqueued. This value may also be NULL in which case a RAW payload is dequeued and enqueued instead.

queue

OUT

A reference to the newly created queue which will be populated upon successful completion of this function. The reference should be released by calling dpiQueue_release() as soon as it is no longer needed.

int dpiConn_newTempLob(dpiConn *conn, dpiOracleTypeNum lobType, dpiLob **lob)

Returns a reference to a new temporary LOB which may subsequently be written and bound to a statement. The reference should be released as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the temporary LOB is to be created. If the reference is NULL or invalid, an error is returned.

lobType

IN

The type of LOB which should be created. It should be one of these values from the enumeration dpiOracleTypeNum: DPI_ORACLE_TYPE_CLOB, DPI_ORACLE_TYPE_NCLOB or DPI_ORACLE_TYPE_BLOB.

lob

OUT

A pointer to a reference to the temporary LOB that is created by this function, which will be populated upon successful completion of this function.

int dpiConn_newVar(dpiConn *conn, dpiOracleTypeNum oracleTypeNum, dpiNativeTypeNum nativeTypeNum, uint32_t maxArraySize, uint32_t size, int sizeIsBytes, int isArray, dpiObjectType *objType, dpiVar **var, dpiData **data)

Returns a reference to a new variable which can be used for binding data to a statement or providing a buffer for querying data from the database. The reference should be released as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection which this variable will be used for binding or querying. If the reference is NULL or invalid, an error is returned.

oracleTypeNum

IN

The type of Oracle data that is to be used. It should be one of the values from the enumeration dpiOracleTypeNum.

nativeTypeNum

IN

The type of native C data that is to be used. It should be one of the values from the enumeration dpiNativeTypeNum.

maxArraySize

IN

The maximum number of rows that can be fetched or bound at one time from the database, or the maximum number of elements that can be stored in a PL/SQL array.

size

IN

The maximum size of the buffer used for transferring data to/from Oracle. This value is only used for variables transferred as byte strings. Size is either in characters or bytes depending on the value of the sizeIsBytes parameter. If the value is in characters, internally the value will be multipled by the maximum number of bytes for each character and that value used instead when determining the necessary buffer size.

sizeIsBytes

IN

A boolean value indicating if the size parameter refers to characters or bytes. This flag is only used if the variable refers to character data.

isArray

IN

A boolean value indicating if the variable refers to a PL/SQL array or simply to buffers used for binding or fetching data.

objType

IN

A reference to the object type of the object that is being bound or fetched. This value is only used if the Oracle type is DPI_ORACLE_TYPE_OBJECT.

var

OUT

A pointer to a reference to the variable that is created by this function.

data

OUT

A pointer to an array of dpiData structures that are used to transfer data to/from the variable. These are allocated when the variable is created and the number of structures corresponds to the maxArraySize.

int dpiConn_ping(dpiConn *conn)

Pings the database to determine if a connection is usable.

This function does the local, light-weight checks of dpiConn_getIsHealthy() and additionally performs a round-trip to the database if the local checks are successful.

The session pool internally may perform this check before returning a connection to the application. This depends on the value of DPI_DEFAULT_PING_INTERVAL and when the connection was returned to the pool.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

If DPI_FAILURE is returned, the application should close the connection.

Parameter

Mode

Description

conn

IN

A reference to the connection which will be pinged. If the reference is NULL or invalid, an error is returned.

int dpiConn_prepareStmt(dpiConn *conn, int scrollable, const char *sql, uint32_t sqlLength, const char *tag, uint32_t tagLength, dpiStmt **stmt)

Returns a reference to a statement prepared for execution. The reference should be released as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection on which the statement is to be prepared. If the reference is NULL or invalid, an error is returned.

scrollable

IN

A boolean indicating if the statement is scrollable or not. If it is scrollable, dpiStmt_scroll() can be used to reposition the cursor; otherwise, rows are retrieved in order from the statement until the rows are exhausted. This value is ignored for statements that do not refer to a query.

sql

IN

The SQL that is to be prepared for execution, as a byte string in the encoding used for CHAR data. The value can also be NULL if the tag parameter is specified.

sqlLength

IN

The length of the SQL that is to be prepared for execution, in bytes, or 0 if the sql parameter is NULL.

tag

IN

The key to be used for searching for the statement in the statement cache, as a byte string in the encoding used for CHAR data. The value can also be NULL if the sql parameter is specified.

tagLength

IN

The length of the key to be used for searching for the statement in the statement cache, in bytes, or 0 if the tag parameter is NULL.

stmt

OUT

A pointer to a reference to the statement that was just prepared, which will be populated upon successful completion of the function.

int dpiConn_release(dpiConn *conn)

Releases a reference to the connection. A count of the references to the connection is maintained and when this count reaches zero, the memory associated with the connection is freed and the connection is closed or released back to the session pool if that has not already taken place using the function dpiConn_close().

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

The connection from which a reference is to be released. If the reference is NULL or invalid, an error is returned.

int dpiConn_rollback(dpiConn *conn)

Rolls back the current active transaction.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection which holds the transaction which is to be rolled back. If the reference is NULL or invalid, an error is returned.

int dpiConn_setAction(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the action attribute on the connection. This is one of the end-to-end tracing attributes that can be tracked in database views, shown in audit trails and seen in tools such as Enterprise Manager.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the action attribute is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the action attribute.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setCallTimeout(dpiConn *conn, uint32_t value)

Sets the call timeout (in milliseconds) to be used for round-trips to the database made with this connection. A value of 0 means that no timeouts will take place. The current value can be acquired using the function dpiConn_getCallTimeout().

The call timeout value applies to each database round-trip individually, not to the sum of all round-trips. Time spent processing in ODPI-C before or after the completion of each round-trip is not counted.

  • If the time from the start of any one round-trip to the completion of that same round-trip exceeds call timeout milliseconds, then the operation is halted and an exception occurs.

  • In the case where an ODPI-C operation requires more than one round-trip and each round-trip takes less than call timeout milliseconds, then no timeout will occur, even if the sum of all round-trip calls exceeds call timeout.

  • If no round-trip is required, the operation will never be interrupted.

After a timeout is triggered, ODPI-C attempts to clean up the internal connection state. The cleanup is allowed to take another value milliseconds.

If the cleanup was successful, an exception DPI-1067 will be raised but the application can continue to use the connection.

For small values of call timeout, the connection cleanup may not complete successfully within the additional call timeout period. In this case an exception ORA-3114 is raised and the connection will no longer be usable. It should be closed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection on which the current call timeout is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

The value to use (in milliseconds) for round-trips to the database made with this connection. A value of 0 means that no timeouts will take place.

int dpiConn_setClientIdentifier(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the client identifier attribute on the connection. This is one of the end-to-end tracing attributes that can be tracked in database views, shown in audit trails and seen in tools such as Enterprise Manager.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the client identifier attribute is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the client identifier attribute.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setClientInfo(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the client info attribute on the connection. This is one of the end-to-end tracing attributes that can be tracked in database views, shown in audit trails and seen in tools such as Enterprise Manager.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the client info attribute is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the client info attribute.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setCurrentSchema(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the current schema to be used on the connection. This has the same effect as the SQL statement ALTER SESSION SET CURRENT_SCHEMA. The value be changed when the next call requiring a round trip to the server is performed. If the new schema name does not exist, the same error is returned as when the alter session statement is executed. The new schema name is placed before database objects in statement that you execute that do not already have a schema.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the current schema is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the current schema.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setDbOp(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the database operation attribute on the connection. This is one of the end-to-end tracing attributes that can be tracked in database views, shown in audit trails and seen in tools such as Enterprise Manager.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the database operation attribute is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the database operation attribute.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setEcontextId(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the execution context id attribute on the connection. This is one of the end-to-end tracing attributes that can be tracked in database views, shown in audit trails and seen in tools such as Enterprise Manager.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the execution context id attribute is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the module attribute.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setExternalName(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the external name that is being used by the connection. This value is used when logging distributed transactions.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the external name is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the external name.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setInternalName(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the internal name that is being used by the connection. This value is used when logging distributed transactions.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the internal name is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the internal name.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setModule(dpiConn *conn, const char *value, uint32_t valueLength)

Sets the module attribute on the connection. This is one of the end-to-end tracing attributes that can be tracked in database views, shown in audit trails and seen in tools such as Enterprise Manager.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the module attribute is to be set. If the reference is NULL or invalid, an error is returned.

value

IN

A pointer to a byte string in the encoding used for CHAR data which will be used to set the module attribute.

valueLength

IN

The length of the value that is to be set, in bytes.

int dpiConn_setOciAttr(dpiConn *conn, uint32_t handleType, uint32_t attribute, void *value, uint32_t valueLength)

Sets the value of an OCI attribute. This is intended solely for testing attributes that are not otherwise supported by ODPI-C and should not be used for any other purpose. Use only as directed by Oracle.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection on which the OCI attribute is to be set. If the reference is NULL or invalid, an error is returned.

handleType

IN

The type of OCI handle that is to be used. This should be one of 3 (service context handle), 8 (server handle) or 9 (session handle).

attribute

IN

The attribute to set.

value

IN

A pointer to the data which is to be set.

valueLength

IN

The length of the data which is to be set.

int dpiConn_setStmtCacheSize(dpiConn *conn, uint32_t cacheSize)

Sets the size of the statement cache.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the size of the statement cache is to be set. If the reference is NULL or invalid, an error is returned.

cacheSize

IN

The new size of the statement cache, in number of statements.

int dpiConn_shutdownDatabase(dpiConn *conn, dpiShutdownMode mode)

Shuts down the database. This function must be called twice for the database to be shut down successfully. After calling this function the first time, the SQL statements “alter database close normal” and “alter database dismount” must be executed. Once that is complete this function should be called again with the mode DPI_MODE_SHUTDOWN_FINAL in order to complete the orderly shutdown of the database.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection to the database which is to be shut down. If the reference is NULL or invalid, an error is returned. The connection needs to have been established at least with authorization mode set to DPI_MODE_AUTH_SYSDBA or DPI_MODE_AUTH_SYSOPER.

mode

IN

One of the values from the enumeration dpiShutdownMode.

int dpiConn_startupDatabaseWithPfile(dpiConn *conn, const char *pfile, uint32_t pfileLength, dpiStartupMode mode)

Starts up a database with a parameter file (PFILE).

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection to the database which is to be started up. If the reference is NULL or invalid, an error is returned. The connection must be created with the authorization mode set to DPI_MODE_AUTH_PRELIM along with one of DPI_MODE_AUTH_SYSDBA or DPI_MODE_AUTH_SYSOPER.

pfile

IN

A pointer to a byte string in the encoding used for CHAR data which identifies the name of the parameter file (PFILE) that will be used to startup the database. This value may be NULL if the pfileLength parameter is zero. In that case this function behaves identically to the dpiConn_startupDatabase() function.

pfileLength

IN

The length of the pfile parameter, in bytes.

mode

IN

One or more of the values from the enumeration dpiStartupMode, OR’ed together.

int dpiConn_startupDatabase(dpiConn *conn, dpiStartupMode mode)

Starts up a database.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection to the database which is to be started up. If the reference is NULL or invalid, an error is returned. The connection must be created with the authorization mode set to DPI_MODE_AUTH_PRELIM along with one of DPI_MODE_AUTH_SYSDBA or DPI_MODE_AUTH_SYSOPER.

mode

IN

One or more of the values from the enumeration dpiStartupMode, OR’ed together.

int dpiConn_subscribe(dpiConn *conn, dpiSubscrCreateParams *params, dpiSubscr **subscr)

Returns a reference to a subscription which is used for requesting notifications of events that take place in the database. Events that are supported are changes on tables or queries (continuous query notification) and the availability of messages to dequeue (advanced queuing). The reference should be released as soon as it is no longer needed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the subscription is to be created. If the reference is NULL or invalid, an error is returned.

params

IN

A pointer to a dpiSubscrCreateParams structure which is used to specify parameters for the subscription. These parameters determine what events will result in notifications.

subscr

OUT

A pointer to a reference to the subscription that is created by this function.

int dpiConn_tpcBegin(dpiConn *conn, dpiXid *xid, uint32_t transactionTimeout, uint32_t flags)

Begins a new TPC (two-phase commit) transaction with the given transaction id (XID).

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the transaction is to begin. If the reference is NULL or invalid, an error is returned.

xid

IN

A pointer to a structure of type dpiXid which identifies the TPC transaction which is to begin.

transactionTimeout

IN

The duration in seconds to wait for a transaction to become available for resumption when the flags parameter is one of DPI_TPC_BEGIN_RESUME or DPI_TPC_BEGIN_JOIN. When DPI_TPC_BEGIN_NEW is specified for the flags parameter, this parameter indicates the number of seconds the transaction can be inactive before it is automatically terminated by the system.

flags

IN

One of the values from the enumeration dpiTpcBeginFlags.

int dpiConn_tpcCommit(dpiConn *conn, dpiXid *xid, int onePhase)

Commits a TPC (two-phase commit) transaction.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the transaction is to be committed. If the reference is NULL or invalid, an error is returned.

xid

IN

A pointer to a structure of type dpiXid which identifies the TPC transaction which is to be committed. If this value is NULL, the XID associated with the connection via the last TPC call is used and this function becomes equivalent to dpiConn_commit().

onePhase

IN

Specifies whether to perform a one phase commit (1) or a two-phase commit (0) if the xid parameter is not NULL. If the xid parameter is NULL the connection already knows what type of commit is needed and this parameter is ignored.

int dpiConn_tpcEnd(dpiConn *conn, dpiXid *xid, uint32_t flags)

Ends a TPC (two-phase commit) transaction with the given transaction id (XID).

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the transaction is to end. If the reference is NULL or invalid, an error is returned.

xid

IN

A pointer to a structure of type dpiXid which identifies the TPC transaction which is to end. If this value is NULL, the XID associated with the connection via the last TPC call is used.

flags

IN

One of the values from the enumeration dpiTpcEndFlags.

int dpiConn_tpcForget(dpiConn *conn, dpiXid *xid)

Forgets a TPC (two-phase commit) transaction.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the transaction is to be forgotten. If the reference is NULL or invalid, an error is returned.

xid

IN

A pointer to a structure of type dpiXid which identifies the TPC transaction which is to be forgotten.

int dpiConn_tpcPrepare(dpiConn *conn, dpiXid *xid, int *commitNeeded)

Prepares a TPC (two-phase commit) transaction for commit. This function should only be called after dpiConn_tpcBegin() is called and before dpiConn_tpcCommit() or dpiConn_commit() is called.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the transaction is to be prepared. If the reference is NULL or invalid, an error is returned.

xid

IN

A pointer to a structure of type dpiXid which identifies the TPC transaction which is to be prepared. If this value is NULL, the XID associated with the connection during the previous call to dpiConn_tpcBegin() is used.

commitNeeded

OUT

A pointer to a boolean value indicating if a commit is needed or not. If no commit is needed, attempting to commit anyway will result in an ORA-24756 error (transaction does not exist).

int dpiConn_tpcRollback(dpiConn *conn, dpiXid *xid)

Rolls back a TPC (two-phase commit) transaction.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the transaction is to be rolled back. If the reference is NULL or invalid, an error is returned.

xid

IN

A pointer to a structure of type dpiXid which identifies the TPC transaction which is to be rolled back. If this value is NULL, the XID associated with the connection via the last TPC call is used and this function becomes equivalent to dpiConn_rollback().

int dpiConn_unsubscribe(dpiConn *conn, dpiSubscr *subscr)

Unsubscribes from the events that were earlier subscribed to via the function dpiConn_subscribe(). Once this function completes successfully no further notifications will be sent for this subscription. Note that this method does not generate a notification either.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

conn

IN

A reference to the connection in which the subscription is to be destroyed. If the reference is NULL or invalid, an error is returned. The connection used to unsubscribe should be the same connection used to subscribe or should access the same database and be connected as the same user name.

subscr

OUT

A pointer to a reference to the subscription that is to be destroyed. A reference will be released and the subscription will no longer be usable once this function completes successfully.