#include "SampleLib.h"
#define SQL_TEXT "begin proc_Demo(:1, :2, :3); end;"
int main(int argc, char **argv)
{
dpiData *inOutValue, *outValue, inValue;
dpiVar *inOutVar, *outVar;
uint32_t numQueryColumns;
dpiStmt *stmt;
dpiConn *conn;
conn = dpiSamples_getConn(0, NULL);
if (dpiConn_prepareStmt(conn, 0, SQL_TEXT, strlen(SQL_TEXT), NULL, 0,
&stmt) < 0)
return dpiSamples_showError();
inValue.isNull = 0;
inValue.value.asBytes.ptr = "In value for demoing";
inValue.value.asBytes.length = strlen("In value for demoing");
if (dpiStmt_bindValueByPos(stmt, 1, DPI_NATIVE_TYPE_BYTES, &inValue) < 0)
return dpiSamples_showError();
if (dpiConn_newVar(conn, DPI_ORACLE_TYPE_NUMBER, DPI_NATIVE_TYPE_INT64, 1,
0, 0, 0, NULL, &inOutVar, &inOutValue) < 0)
return dpiSamples_showError();
inOutValue->isNull = 0;
inOutValue->value.asInt64 = 347;
if (dpiStmt_bindByPos(stmt, 2, inOutVar) < 0)
return dpiSamples_showError();
if (dpiConn_newVar(conn, DPI_ORACLE_TYPE_NUMBER, DPI_NATIVE_TYPE_INT64, 1,
0, 0, 0, NULL, &outVar, &outValue) < 0)
return dpiSamples_showError();
if (dpiStmt_bindByPos(stmt, 3, outVar) < 0)
return dpiSamples_showError();
if (dpiStmt_execute(stmt, 0, &numQueryColumns) < 0)
return dpiSamples_showError();
printf("IN/OUT value (after call) is %" PRId64 "\n",
inOutValue->value.asInt64);
dpiVar_release(inOutVar);
printf("OUT value (after call) is %" PRId64 "\n", outValue->value.asInt64);
dpiVar_release(outVar);
dpiStmt_release(stmt);
dpiConn_release(conn);
printf("Done.\n");
return 0;
}