OCIDefineByPos通过C++中的光标提取NUMBER值
OCIDefineByPos extract NUMBER value via cursor in C++
继通过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++整数/浮点的方法,但这可以。
相关文章:
- 从包含m行的文件中提取n行,必要时(惰性地)重复该文件
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么istream不支持右值提取
- 如何设置一个范围来提取我想要获得的信息
- 具有变量Number of Arguments的std::函数的矢量
- 视觉工作室项目.提取源文件夹名称
- C++17 - 使用自定义分配器的节点提取/重新插入 - 适用于 clang++/libc++,但不适用于 libstd
- 从字符串中提取整数并形成一个数组
- C ++中的StringStream有助于使用向量从字符串中提取逗号分隔的整数,而不是空格分隔的整数,为什么?
- asn1c 不会从 asn.1 模块中提取八位字节字符串的默认值
- 从 std::vector<无符号字符>切片中提取 int?
- 在C++中使用重载提取运算符时出现问题
- 在 Qt(C++) 中使用 QProcess 解压缩 - 提取目录问题
- C++(.cpp文件和.h文件)拆分代码并添加一个函数,提取 - 这很容易吗?
- 无法从 std::string 中提取C++ Unicode 符号
- 如何从也包含C++字母的文本文件中提取某些数字?
- 如何从适合一定范围的数字中提取数字?
- C++从通用引用中提取实际类型
- 从运行服务的应用程序代码中提取窗口句柄
- OCIDefineByPos通过C++中的光标提取NUMBER值