亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1843 | 回復: 0
打印 上一主題 下一主題

一個關(guān)于OCIBINDBYPOS的錯誤(附代碼) [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2006-12-20 17:11 |只看該作者 |倒序瀏覽
代碼如下:
#define BATCHRECORDNUM 5        //批量插入的記錄條數(shù)
#define DATASIZE 8192                        //預分配空間的大小

char ***pBuffer;                                        //數(shù)據(jù)緩沖區(qū)指針
int colNum;                                                                //記錄字段個數(shù)

....

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);
        }
}
...

//取數(shù)據(jù)
for (Rec = 0; Rec< Result.RecordNum; Rec++)
{       
        for(i = 0; i < colNum; i++)
        {
                //此處取出數(shù)據(jù)存入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));
                }
     
   
        //!。〈颂幊鲥e
        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);
}

取數(shù)據(jù)的部分沒有問題,總是執(zhí)行到OCIStmtExecute報錯,判斷是OCIBINDBYPOS錯誤,但是找不到錯誤在哪里,請教一下高手!
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP