php获取js select0量,OCI批量获取Select结果,记要数为0

在 OCI 应用中,尝试通过 SQL 语句批量获取 'foo' 表的记录数,但无论使用 OCI_ATTR_PREFETCH_ROWS 还是 OCI_ATTR_ROW_COUNT,结果始终为0。尽管表中有20条记录。问题可能涉及到 OCI 函数调用的正确性或执行上下文。检查代码中 OCI 函数的使用和错误处理是解决问题的关键。
摘要由CSDN通过智能技术生成

OCI批量获取Select结果,记录数为0

char *sqlstr = "select count(*) from foo";

static ub4 FpreFetch = 10;

int rowCount;

//装载查询语句

rc = OCIStmtPrepare(pSql, pErr, (OraText*)sqlstr, strlen(sqlstr), OCI_NTV_SYNTAX, OCI_DEFAULT);

rc = OCIAttrSet(pSql, OCI_HTYPE_STMT, &FpreFetch, (ub4)sizeof(ub4), OCI_ATTR_PREFETCH_ROWS, pErr);

rc==0?NULL:err_handler(pErr);

rc = OCIStmtExecute(pCtx, pSql, pErr, (ub4)NULL, (ub4)NULL, NULL, NULL, OCI_RESULT_CACHE);

rc==0?NULL:err_handler(pErr);

rc = OCIAttrGet(pSql, OCI_HTYPE_STMT, &rowCount, NULL, OCI_ATTR_ROWS_FETCHED, pErr);//

rc==0?NULL:err_handler(pErr);

rc = OCIAttrGet(pSql, OCI_HTYPE_STMT, &rowCount, NULL, OCI_ATTR_ROW_COUNT, pErr);//结果集行数

rc==0?NULL:err_handler(pErr);

程序执行时我表中有20条记录,但是两个rowCount都是0。希望了解OCI的朋友指点一下。

OCI 批量获取数据 结果为0

分享到:

------解决方案--------------------

Program Name                              Features Illustrated

cdemo81.c                                 Using basic SQL processing with release 8 and later functionality.

cdemo82.c                                 Performing basic processing of user-defined objects.

cdemocor.c                                Using complex object retrieval (COR) to improve performance.

cdemodr1.c,cdemodr2.c,cdemodr3.c          Using INSERT/UPDATE/DELETE statements with RETURNING clause used with basic datatypes, LOBs and REFs.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值