9.17. ODPI-C SODA Database Functions

SODA database handles are used to represent connections to the SODA database. They are created by calling the function dpiConn_getSodaDb(). They are destroyed when the last reference is released by calling dpiSodaDb_release().

See this tracking issue for known issues with SODA.

int dpiSodaDb_addRef(dpiSodaDb *db)

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

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

db

IN

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

int dpiSodaDb_createCollection(dpiSodaDb *db, const char *name, uint32_t nameLength, const char *metadata, uint32_t metadataLength, uint32_t flags, dpiSodaColl **coll)

Creates a new SODA collection if a collection by that name does not exist. If a collection by that name already exists, the collection is opened if the metadata of the collection is equivalent to the supplied metadata; otherwise, an error is returned.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

NOTE: the creation of the collection is performed using an autonomous transaction. Any current transaction is left unchanged.

Parameter

Mode

Description

db

IN

A reference to the database in which the SODA collection is to be created. If the reference is NULL or invalid, an error is returned.

name

IN

The name of the collection which is to be created or opened. NOTE: the name is case sensitive.

nameLength

IN

The length of the name parameter, in bytes.

metadata

IN

The metadata to use when creating the collection, or NULL if default metadata should be used instead.

metadataLength

IN

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

flags

IN

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

coll

OUT

A pointer to a reference to the newly created or opened SODA collection if the function completes successfully. The function dpiSodaColl_release() should be called when the collection is no longer required.

int dpiSodaDb_createDocument(dpiSodaDb *db, const char *key, uint32_t keyLength, const char *content, uint32_t contentLength, const char *mediaType, uint32_t mediaTypeLength, uint32_t flags, dpiSodaDoc **doc)

Creates a SODA document that can later be inserted into a collection or used to replace an existing document in a collection. This method should be used when the content is binary or encoded text.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

db

IN

A reference to the database in which the SODA document is going to be inserted or replaced. If the reference is NULL or invalid, an error is returned.

key

IN

The key used to identify this document, or NULL if a key should be generated instead (and the collection metadata supports key generation).

keyLength

IN

The length of the key used to identify the document, in bytes, or 0 if the key is NULL.

content

IN

The content of the document to create, as a byte string. The type of content is controlled by the mediaType parameter. If the mediaType parameter is set to NULL or “application/json”, the content must be a valid UTF-8 or UTF-16 encoded JSON string.

contentLength

IN

The length of the document content, in bytes.

mediaType

IN

The type of content that is found in the content parameter. This value may also be NULL, in which case the default value of “application/json” is assumed.

mediaTypeLength

IN

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

flags

IN

Currently unused.

doc

OUT

A pointer to a document reference that will be populated upon successful completion of this function. Call the function dpiSodaDoc_release() when it is no longer needed.

int dpiSodaDb_createJsonDocument(dpiSodaDb *db, const char *key, uint32_t keyLength, const dpiJsonNode *content, uint32_t flags, dpiSodaDoc **doc)

Creates a SODA document that can later be inserted into a collection or used to replace an existing document in a collection. This method should be used when the content is JSON and Oracle Client 23 or higher is being used.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

db

IN

A reference to the database in which the SODA document is going to be inserted or replaced. If the reference is NULL or invalid, an error is returned.

key

IN

The key used to identify this document, or NULL if a key should be generated instead (and the collection metadata supports key generation).

keyLength

IN

The length of the key used to identify the document, in bytes, or 0 if the key is NULL.

content

IN

The content of the document to create, as a value of type dpiJsonNode.

flags

IN

Currently unused.

doc

OUT

A pointer to a document reference that will be populated upon successful completion of this function. Call the function dpiSodaDoc_release() when it is no longer needed.

int dpiSodaDb_getCollections(dpiSodaDb *db, const char *startName, uint32_t startNameLength, uint32_t flags, dpiSodaCollCursor **cursor)

Return a cursor to iterate over the SODA collections available in the database.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

db

IN

A reference to the database to use for iterating over available SODA collections. If the reference is NULL or invalid, an error is returned.

startName

IN

A name from which to start iterating over collections available in the database or NULL if all collections should be returned.

startNameLength

IN

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

flags

IN

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

cursor

OUT

A pointer to a reference to a newly allocated cursor if the function completes successfully. The function dpiSodaCollCursor_getNext() should be used to get the next collection from the database and dpiSodaCollCursor_release() should be used when the cursor is no longer required.

int dpiSodaDb_getCollectionNames(dpiSodaDb *db, const char *startName, uint32_t startNameLength, uint32_t limit, uint32_t flags, dpiStringList *names)

Return an array of names of SODA collections available in the database.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

db

IN

A reference to the database to use for getting the names of available SODA collections. If the reference is NULL or invalid, an error is returned.

startName

IN

The value from which to start getting the names of collections available in the database or NULL if the names of all collections should be returned.

startNameLength

IN

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

limit

IN

The maximum number of collection names to return, or 0 if all names matching the criteria should be returned.

flags

IN

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

names

IN

A pointer to structure of type dpiStringList which will be populated upon successful completion of this function. A call to the function dpiContext_freeStringList() should be made once the names of the collections returned in this structure are no longer needed.

int dpiSodaDb_openCollection(dpiSodaDb *db, const char *name, uint32_t nameLength, uint32_t flags, dpiSodaColl **coll)

Opens an existing SODA collection.

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

db

IN

A reference to the database in which the SODA collection is to be opened. If the reference is NULL or invalid, an error is returned.

name

IN

The name of the collection which is to be opened. NOTE: the name is case sensitive.

nameLength

IN

The length of the name parameter, in bytes.

flags

IN

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

coll

OUT

A pointer to a reference to the newly opened SODA collection if the function completes successfully. The function dpiSodaColl_release() should be called when the collection is no longer required. If the collection with the specified name does not exist, the returned reference is NULL and no error is returned.

int dpiSodaDb_release(dpiSodaDb *db)

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

The function returns DPI_SUCCESS for success and DPI_FAILURE for failure.

Parameter

Mode

Description

db

IN

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