继通过 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++;
}
任何指向正确方向的指针都将不胜感激(如果我错过了一些简单的事情,我们深表歉意!)。谢谢