各位大大:
    我使用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_Re;         

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_Re, 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,怎么样更好一点?

解决方案 »

  1.   

    1、建议方法,在语句中处理
    char chrSqlStr[512] = "INSERT INTO T_TABLE (NAME,AGE) VALUES (case when :1<1 then null else :1 end ,:2)";
    2、各使用各的接口 
      

  2.   

    用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_Re, myerrhp, 2, (dvoid *)&iAge,  sizeof(int), SQLT_INT, &Flag, 0, 0, 0, 0, OCI_DEFAULT); 
    少了对批示符变量地址的强制转换(dvoid*),可我不确定这是不是偶尔能实现,因为我最初按照参考的方法在调的时候也是
    能实现的,但上了系统后就出问题了
    用同样的方法作输出变量是否空值的判断也得不到正确结果,看来ORACLE参考上的说法我还没弄清楚
      

  3.   

    我提供的方法仅从oracle角度讲
    oci不熟悉。
      

  4.   

    oracle里面插入语句不是这样的么
    INSERT INTO T_TABLE (NAME,AGE) VALUES ('1',2); 
    这样传值可以吗?  
    INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,:2); 
      

  5.   

    在OCI中,SQL语句中的占位符变量用于指示数据必须存储的实际位置,占位符变量通过冒号来表示,如:1
    使用占位符可以动态插入多条记录,提高SQL语句的使用效率。如向学生信息表中插入多个学生的资料。
    对于每个占位符,可以调用OCI函数来绑定其对应的变量地址。在执行SQL语句时,ORACLE会将得到的输入数据、绑定数据或变量值传给服务器端,与服务器端实时交互。
    绑定占位符主要有以下几种方式
    1、OCIBindByName()
    2、OCIBindByPos()
    3、OCIBindObject()
    4、OCIBindDynamic()
    5、OCIBindArrayOfStruct()