使用指示符变量向ORACLE表中插入空值的问题
各位大大:
我使用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,怎么样更好一点?