OCIDefineByPos通过C++中的光标提取NUMBER值

OCIDefineByPos extract NUMBER value via cursor in C++

本文关键字:提取 NUMBER 光标 通过 C++ OCIDefineByPos      更新时间:2023-10-16

继通过OCI调用Oracle存储过程并在C++中使用out ref游标返回结果之后,我想提取一个NUMBER列并将结果存储为双精度或长精度(截断)。

总之,我通过OCI调用一个oracle存储过程,使用sys ref_cursor来提交结果。我已经可以使用char[]轻松地提取VARCHAR2列,但是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++;
}

任何指向正确方向的指示都将不胜感激(如果我错过了一些简单的东西,请道歉!)。感谢

使用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);

我还没有找到直接向OCIDefineByPos提供C/C++整数/浮点的方法,但这可以。