Chinaunix
标题:
(附代码)关于OCI的一个问题
[打印本页]
作者:
leeleec
时间:
2006-12-20 17:16
标题:
(附代码)关于OCI的一个问题
代码如下:
#define BATCHRECORDNUM 5 //批量插入的记录条数
#define DATASIZE 8192 //预分配空间的大小
char ***pBuffer; //数据缓冲区指针
int colNum; //记录字段个数
....
pBuffer = (char ***) malloc(sizeof(char **) * BATCHRECORDNUM);
for(i = 0; i < BATCHRECORDNUM; i++)
{
pBuffer[i] = (char **) malloc(sizeof(char *) * colNum);
}
...
for (Rec = 0; Rec < BATCHRECORDNUM; Rec++)
{
for(i = 0; i < colNum; i++)
{
...
pBuffer[Rec][i] = (char *) malloc(sizeof(char) * DATASIZE);
memset(pBuffer[Rec][i], '\0', sizeof(char) * DATASIZE);
}
}
...
//取数据
for (Rec = 0; Rec< Result.RecordNum; Rec++)
{
for(i = 0; i < colNum; i++)
{
//此处取出数据存入pBuffer[Rec][i]
...
buffsize = DATASIZE - 1;
}
//当读取BATCHRECORDNUM条记录时,导入一次
if(Rec % BATCHRECORDNUM == BATCHRECORDNUM-1)
{
checkerr(myerrhp, OCIHandleAlloc( (dvoid *) myenvhp, (dvoid **) &stmthp, OCI_HTYPE_STMT, 0, 0));
checkerr(myerrhp, OCIStmtPrepare(stmthp, myerrhp, (text *) chInsertTemplate, (ub4)strlen(chInsertTemplate), OCI_NTV_SYNTAX, OCI_DEFAULT));
for(j = 0; j < colNum; j++)
{
checkerr( myerrhp, OCIBindByPos(stmthp, &bndp[j], myerrhp, j + 1, (dvoid *)pBuffer[0][j],
(sword) sizeof(pBuffer[0][j]), colType[j], 0, 0, 0, 0, 0, OCI_DEFAULT));
checkerr(myerrhp, OCIBindArrayOfStruct(bndp[j] , myerrhp, sizeof(pBuffer[0][j]), 0, 0, 0));
}
//!!!此处出错
if((status = OCIStmtExecute(mysvchp, stmthp, myerrhp, (ub4) BATCHRECORDNUM, (ub4) 0, (OCISnapshot *) NULL, (OCISnapshot *) NULL, OCI_DEFAULT)))
{
exporterr("Execute batch insert task error!", __FILE__, (char *)__FUNCTION__, __LINE__);
checkerr(myerrhp, status);
return -1;
}
nImportFlag = 0;
}
}
if(Rec % BATCHRECORDNUM != BATCHRECORDNUM-1 && nImportFlag == 1)
{
checkerr(myerrhp, OCIHandleAlloc( (dvoid *) myenvhp, (dvoid **) &stmthp, OCI_HTYPE_STMT, 0, 0));
checkerr(myerrhp, OCIStmtPrepare(stmthp, myerrhp, (text *) chInsertTemplate, (ub4)strlen(chInsertTemplate), OCI_NTV_SYNTAX, OCI_DEFAULT));
for(j = 0; j < colNum; j++)
{
checkerr( myerrhp, OCIBindByPos(stmthp, &bndp[j], myerrhp, j + 1, (dvoid *)pBuffer[0][j],
(sword) sizeof(pBuffer[0][j]), colType[j], 0, 0, 0, 0, 0, OCI_DEFAULT));
checkerr(myerrhp, OCIBindArrayOfStruct(bndp[j] , myerrhp, sizeof(pBuffer[0][j]), 0, 0, 0));
}
if((status = OCIStmtExecute(mysvchp, stmthp, myerrhp, (ub4) ((Result.RecordNum)%1000), (ub4) 0,
(OCISnapshot *) NULL, (OCISnapshot *) NULL, OCI_DEFAULT)))
{
exporterr("Execute batch insert task error!", __FILE__, (char *)__FUNCTION__, __LINE__);
checkerr(myerrhp, status);
return -1;
}
nImportFlag = 0;
}
/* Commit the change. */
if (status = OCITransCommit(mysvchp, myerrhp, 0))
{
checkerr(myerrhp, status);
}
用GDB跟踪取数据的部分没有问题,总是执行到OCIStmtExecute报错,判断是OCIBINDBYPOS错误,但是找不到错误在哪里,请教一下高手!
作者:
gangjh
时间:
2006-12-21 08:25
樓主代碼貼得也不全
也有點亂,
有心測試一下也只好放棄了
作者:
我要学C
时间:
2006-12-21 10:32
欢迎linux下C程序员及爱好C编程的进取人士!号是:29697377
作者:
leeleec
时间:
2006-12-21 16:31
呵呵,谢谢二楼的。
我目前简化了问题,改成了一条一操作的方式。
现在的问题是当有DATE字段时,插入出错!读取的数据是字符串,如"1997.01.01",报
Error - ORA-01483: invalid length for DATE or NUMBER bind variable
的错误,请教如何将DATE类型数据通过OCIbindbypos插入数据库,非要
使用insert into temp(date1, char1) values(to_date(:date1, "YYYY-MM-DD", :char1)进行绑定才可以吗?
这种方式的弊端在于对于输入的日期数据格式有了限制,不够灵活啊!
谁能给点建议?谢谢
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2