各位大大:
我使用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,怎么样更好一点?
我使用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,怎么样更好一点?
解决方案 »
- 如何安全的消除表空间内的碎片?
- 如何在存储过程中像另外一个数据库的表中插入数据
- ORACLE 排序
- 有一些小问题~ :)
- *小问题:存储过程中如何返回数据集?
- oracle9i通过什么工具对表和字段进行操作?应该有图形界面工具吧?
- 这个SQL语句如何写
- 各位:怎么把一个数据库和一个用户联系到一起来呢,比如现在有一个数据库mydb,我在sqlplus里登录时,就要用admin这个用户登录到mydb这个数
- 一个比较讨厌的问题,请大家帮忙出主意,解决结贴
- ************ORACLE超级难题***********************
- Web Service响应速度的疑惑
- oracle用指定的时间做查询条件怎么查不出数据。
char chrSqlStr[512] = "INSERT INTO T_TABLE (NAME,AGE) VALUES (case when :1<1 then null else :1 end ,:2)";
2、各使用各的接口
"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参考上的说法我还没弄清楚
oci不熟悉。
INSERT INTO T_TABLE (NAME,AGE) VALUES ('1',2);
这样传值可以吗?
INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,:2);
使用占位符可以动态插入多条记录,提高SQL语句的使用效率。如向学生信息表中插入多个学生的资料。
对于每个占位符,可以调用OCI函数来绑定其对应的变量地址。在执行SQL语句时,ORACLE会将得到的输入数据、绑定数据或变量值传给服务器端,与服务器端实时交互。
绑定占位符主要有以下几种方式
1、OCIBindByName()
2、OCIBindByPos()
3、OCIBindObject()
4、OCIBindDynamic()
5、OCIBindArrayOfStruct()