oracle — OCIDefineByPos извлекает значение NUMBER с помощью курсора в переполнении стека

Исходя из Вызовите хранимую процедуру Oracle через OCI и верните результаты с указателем out ref в C ++. Я хочу извлечь столбец NUMBER и сохранить результат в двойном или длинном (усеченном).

Таким образом, я вызываю хранимую процедуру оракула через OCI, используя sys ref_cursor для проверки результатов. Я уже могу легко извлечь столбцы VARCHAR2, используя char [], однако столбцы NUMBER не работают (мне нужен только целочисленный компонент).

Таблица определяется как:

CREATE TABLE FXT_CON_RULES
(
SET_NAM VARCHAR2(12),
CC_TYPE VARCHAR2(8),
AMT_FLOOR NUMBER,
METHOD_FLG" CHAR(1),
BASIS_POINTS" NUMBER(10,1)
)

Сохраненный процесс:

CREATE OR REPLACE PROCEDURE FXT_TEST_CALL(CRESULTS OUT SYS_REFCURSOR) IS
sTESTQUERY                             VARCHAR2(4000);
BEGIN
sTESTQUERY := '
SELECT
set_nam,
cc_type,
amt_floor,
method_flg,
basis_points
from
fxt_con_rules c';

OPEN CRESULTS FOR sTESTQUERY;
END FXT_TEST_CALL;

Я пытался использовать SQLT_NUM, SQLT_INT, SQLT_VNU, используя переменные как long (также long long), так и double, однако я до сих пор не смог получить из него целое значение, отличное от 0.
Фрагмент кода:

char set_nam[40];
double amt_floord = 0;

int answer = OCIStmtExecute(g_pOciServiceContext, pOciStatement, pOciError, 1, 0, NULL, NULL, OCI_COMMIT_ON_SUCCESS);
answer = OCIDefineByPos(cursor,&pOciDefine, pOciError,1,set_nam,40, SQLT_STR, 0, 0, 0,OCI_DEFAULT);
answer = OCIDefineByPos(cursor,&pOciDefine2, pOciError,3,&amt_floord,sizeof(amt_floord), SQLT_NUM, 0, 0, 0,OCI_DEFAULT);

int blah = 0;
while ((answer = OCIStmtFetch(cursor,pOciError, 1,OCI_FETCH_NEXT,OCI_DEFAULT)) == 0)
{
// longTest is always zero while set_name is populated correctly
long long longTest = static_cast<long long>(amt_floord);
blah++;
}

Любые указатели в правильном направлении будут высоко оценены (извинения, если я пропустил что-то простое!).
Спасибо

0

Решение

Решение найдено с использованием предоставленного Oracle класса Number.
OCINumber numTest;

answer = OCIDefineByPos(cursor,&pOciDefine2, pOciError,3,&numTest,sizeof(OCINumber), SQLT_VNU, 0, 0, 0,OCI_DEFAULT);

long long longNum =  0;
OCINumberToInt(pOciError, &numTest, sizeof(long long), OCI_NUMBER_SIGNED , &longNum);

Я не нашел способа предоставить целочисленное / с плавающей запятой C / C ++ непосредственно в OCIDefineByPos, но это подойдет.

0

Другие решения


По вопросам рекламы [email protected]