使用的SQL以下: sql
1. create table test_oci(id number,val varchar2(200));
2. CREATE OR REPLACE PACKAGE UPDATE_TEST_OCI AS
TYPE ID_T IS TABLE OF TEST_OCI.ID%TYPE INDEX BY BINARY_INTEGER;
TYPE VAL_T IS TABLE OF TEST_OCI.VAL%TYPE INDEX BY BINARY_INTEGER;
PROCEDURE ADD_TEST_OCI(N IN NUMBER, V_ID IN ID_T, V_VAL IN VAL_T);
END;
3. CREATE OR REPLACE PACKAGE BODY UPDATE_TEST_OCI AS
PROCEDURE ADD_TEST_OCI(N IN NUMBER, V_ID IN ID_T, V_VAL IN VAL_T) AS
BEGIN
FOR I IN 1 .. N LOOP
INSERT INTO TEST_OCI VALUES (V_ID(I), V_VAL(I));
END LOOP;
COMMIT;
END;
END;
數據庫
假設環境句柄,錯誤句柄,服務器句柄,上下文句柄,語句句柄已分配就緒,且已鏈接數據庫並開始會話。 編程
代碼以下:
{
OCISvcCtx *svr;
OCIStmt *stmt;
OCIError *err;
char sql[]="BEGIN \
UPDATE_TEST_OCI.ADD_TEST_OCI(:n,:id,:val); \
END;";
/*分析沒有問題*/
OCIStmtPrepare(stmt,err,(text*)sql,(ub4)strlen(sql),OCI_NTV_SYNTAX,OCI_DEFAULT);
{
OCIBind *nbd;
int n;
ub2 n_rlen=sizeof(int);
sb2 n_ind=0;
ub2 n_rcode=0;
OCIBind *idbd;
int id[3]={1,2,3};
ub2 id_rlen[3]={sizeof(int),sizeof(int),sizeof(int)};
sb2 id_ind[3]={0,0,0};
ub2 id_rcode[3]={0,0,0};
ub4 id_cur=3;
OCIBind *valbd;
char val[3][20]={"test1","test2","test3"};
ub2 val_rlen[3]={sizeof(val[0]),sizeof(val[1]),sizeof(val[2])};
sb2 val_ind[3]={0,0,0};
ub2 val_rcode[3]={0,0,0};
ub4 val_cur=3;
/*綁定也沒問題*/
OCIBindByName(stmt,&nbd,err,":n",strlen(":n"),&n,sizeof(int),SQLT_INT,&n_ind,&n_rlen,&n_rcode,0,0,OCI_DEFAULT);
OCIBindByName(stmt,&idbd,err,":id",strlen(":id"),&id,sizeof(int),SQLT_INT,id_ind,id_rlen,id_rcode,id_cur,&id_cur,OCI_DEFAULT);
OCIBindArrayOfStruct(idbd,err,sizeof(int),sizeof(sb2),sizeof(ub2),sizeof(ub2));
OCIBindByName(stmt,&valbd,err,":val",strlen(":val"),&val,sizeof(val[0]),SQLT_STR,val_ind,val_rlen,val_rcode,id_cur,&id_cur,OCI_DEFAULT);
OCIBindArrayOfStruct(valbd,err,sizeof(val[0]),sizeof(sb2),sizeof(ub2),sizeof(ub2));
}
/*執行沒有任何反應,編程成64位程序,使用64位客戶端能夠執行成功*/
OCIStmtExecute(svr,stmt,err,1,0,0,0,OCI_DEFAULT);
}
但若是修改分析的語句成爲: 服務器
... spa
char sql[]="BEGIN \
UPDATE_TEST_OCI.ADD_TEST_OCI(3,:id,:val); \
END;"
... code
OCIBindByName(stmt,&idbd,err,":id",strlen(":id"),&id,sizeof(int),SQLT_INT,id_ind,id_rlen,id_rcode,id_cur,&id_cur,OCI_DEFAULT);
OCIBindArrayOfStruct(idbd,err,sizeof(int),sizeof(sb2),sizeof(ub2),sizeof(ub2));
OCIBindByName(stmt,&valbd,err,":val",strlen(":val"),&val,sizeof(val[0]),SQLT_STR,val_ind,val_rlen,val_rcode,id_cur,&id_cur,OCI_DEFAULT);
OCIBindArrayOfStruct(valbd,err,sizeof(val[0]),sizeof(sb2),sizeof(ub2),sizeof(ub2)); ci
綁定:id,:val佔位符,32位客戶端則執行成功。 若是使用v7版本的OCI操做,不管那種狀況都會成功執行。