9.23. ODPI-C Vector Functions

Vector handles are used to represent vector values stored in the database. They are only available from Oracle Client and Database 23.4 and higher. They can be created explicitly by a call to dpiConn_newVector() or implicitly when a variable of type DPI_ORACLE_TYPE_VECTOR is created. They are destroyed when the last reference is released by a call to the function dpiVector_release().

int dpiVector_addRef(dpiVector *vector)

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

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

vector

IN

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

int dpiVector_getValue(dpiVector *vector, dpiVectorInfo *info)

Returns information about the vector.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

vector

IN

The vector value from which the information is to be extracted. If the reference is NULL or invalid, an error is returned.

info

OUT

A pointer to a structure of type dpiVectorInfo which will be populated upon successful completion of this function. The structure’s contents will remain valid as long as a reference is held to the vector value and the vector value itself is not modified.

int dpiVector_release(dpiVector *vector)

Releases a reference to the vector value. A count of the references to the vector value is maintained and when this count reaches zero, the memory associated with the vector value is freed.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

vector

IN

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

int dpiVector_setValue(dpiVector *json, dpiVectorInfo *info)

Sets the vector value from the supplied information.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

vector

IN

The vector value which is to be modified using the supplied information. If the reference is NULL or invalid, an error is returned.

info

IN

A pointer to a structure of type dpiVectorInfo which contains the information to be set on the vector.