OCI编程中BindByPos绑定时总出错,求解!!!

Allen0208 2012-07-31 03:49:28
OCI编程时,我绑定的数据如果为数值型字符串时(char * sno[] = "123"),最后可以成功入库,但如果绑定不为数值字符串(char * sno[] = "abc")时,总不能入库,不知为何,求高手指点。部分代码如下:


if(g_IndbInterFace.ConnectToDB(chUserName, chPassword, chServerName))
{
printf("can not connect to DB!");
return -1;
}
printf("connect succeed!\n");

int status;
char no[] = "333";
char name[] = "aaa";
OCIBind *bndhp1, *bndhp2;
char chInsertArray[1024];

sprintf(chInsertArray,"insert into s(sno,sname) values(%s,%s)",no,name);

g_IndbInterFace.SqlBind(chInsertArray);

if(status=OCIBindByPos(stmthp,&bndhp1,errhp,(ub4)(1),
(dvoid *)(no),(sb4)(FIELD_LEN+1),
SQLT_STR,(dvoid *)0,(ub2 *)0,(ub2 *)0,
(ub4)0, (ub4 *)0,(ub4)OCI_DEFAULT))
{
WriteAlert("DataInBind(433) FAILED: OCIBindByPos()");
}
if(status=OCIBindByPos(stmthp,&bndhp2,errhp,(ub4)(2),
(dvoid *)(&b),(sb4)(FIELD_LEN+1),
SQLT_STR,(dvoid *)0,(ub2 *)0,(ub2 *)0,
(ub4)0, (ub4 *)0,(ub4)OCI_DEFAULT))
{
WriteAlert("DataInBind(433) FAILED: OCIBindByPos()");
}
g_IndbInterFace.DataInExec(1,0);
g_IndbInterFace.TransCommit();
g_IndbInterFace.DisConnectToDB();
...全文
378 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

64,642

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧