使用指示符变量向ORACLE表中插入空值的问题

li602714 2009-04-02 12:04:59
各位大大:
我使用OCI接口访问ORACLE,在向表中插入记录时要根据变量值确定是否插入空值,因此我使用了指示符变量,代码如下:
bool COracle::InsertIntoTable(char* pcName, int& iAge)
{
//SQL语句
char chrSqlStr[512] = "INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,:2)";
sb2 Flag;
//定义绑定句柄
OCIBind* bindhp_Prompt;
OCIBind* bindhp_Remark;

OCIStmtPrepare(mystmthp, myerrhp, (text *)chrSqlStr, strlen(chrSqlStr), OCI_NTV_SYNTAX, OCI_DEFAULT)) )

//位置绑定
if ( strlen(pcName) >= 0 ) Flag=-1; else Flag=0;
OCIBindByPos(mystmthp, &bindhp_Prompt, myerrhp, 1, (dvoid *)pcName, 15, SQLT_STR, (dvoid*)&Flag, 0, 0, 0, 0, OCI_DEFAULT);

if ( iAge <= 0 ) Flag=-1; else Flag=0;
OCIBindByPos(mystmthp, &bindhp_Remark, myerrhp, 2, (dvoid *)&iAge, sizeof(int), SQLT_INT, (dvoid*)&Flag, 0, 0, 0, 0, OCI_DEFAULT);

//执行
OCIStmtExecute(mysvchp, mystmthp, myerrhp, 1, 0, NULL, NULL, OCI_COMMIT_ON_SUCCESS);
return true;
}

我是原意是当iAge的值小于1时,AGE字段就插入空值,这段代码在大部份时候不能正确插入空值,但偶尔也可以插入空值,不明白是为什么?
请教各位大大,谢谢

另外请问,我的程序里要提供ACCESS, SQLSERVER,ORACLE三种数据库的接口,是使用一种访问方式好,还是各用各的访问方式好,像ORACLE我就一直用的OCI,但其它的显然不能用OCI,怎么样更好一点?
...全文
661 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
li602714 2009-04-13
  • 打赏
  • 举报
回复
知道的同志来看看啊
li602714 2009-04-07
  • 打赏
  • 举报
回复
在OCI中,SQL语句中的占位符变量用于指示数据必须存储的实际位置,占位符变量通过冒号来表示,如:1
使用占位符可以动态插入多条记录,提高SQL语句的使用效率。如向学生信息表中插入多个学生的资料。
对于每个占位符,可以调用OCI函数来绑定其对应的变量地址。在执行SQL语句时,ORACLE会将得到的输入数据、绑定数据或变量值传给服务器端,与服务器端实时交互。
绑定占位符主要有以下几种方式
1、OCIBindByName()
2、OCIBindByPos()
3、OCIBindObject()
4、OCIBindDynamic()
5、OCIBindArrayOfStruct()
jdsnhan 2009-04-06
  • 打赏
  • 举报
回复
我提供的方法仅从oracle角度讲
oci不熟悉。
cheng_fengming 2009-04-06
  • 打赏
  • 举报
回复
oracle里面插入语句不是这样的么
INSERT INTO T_TABLE (NAME,AGE) VALUES ('1',2);
这样传值可以吗?
INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,:2);
li602714 2009-04-03
  • 打赏
  • 举报
回复
用1楼的方法试了一下,
"INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,case when :2 <1 then null else :2 end)";
发现OCIStmtExecute时会出错,调用OCIErrorGet得到信息是"ORA-01008:并非所有变量都已绑定",但我是绑定了的,指示符变量的位置写的是"0"
是我什么地方没注意到吗?在end后面加逗号也不行

后来偶然试到用如下绑定语句可以实现
OCIBindByPos(mystmthp, &bindhp_Remark, myerrhp, 2, (dvoid *)&iAge, sizeof(int), SQLT_INT, &Flag, 0, 0, 0, 0, OCI_DEFAULT);
少了对批示符变量地址的强制转换(dvoid*),可我不确定这是不是偶尔能实现,因为我最初按照参考的方法在调的时候也是
能实现的,但上了系统后就出问题了
用同样的方法作输出变量是否空值的判断也得不到正确结果,看来ORACLE参考上的说法我还没弄清楚
jdsnhan 2009-04-02
  • 打赏
  • 举报
回复
1、建议方法,在语句中处理
char chrSqlStr[512] = "INSERT INTO T_TABLE (NAME,AGE) VALUES (case when :1<1 then null else :1 end ,:2)";
2、各使用各的接口

17,140

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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