当前位置:Gxlcms > 数据库问题 > 二进制数据库的存取

二进制数据库的存取

时间:2021-07-01 10:21:17 帮助过:2人阅读

 这里,我们以float一维数组的形式存储多个点的坐标: 

思路:先将float数组转化为char数组,然后将其转化为safeArray并存储到BLOB数据中,然后存储在数据库中的image字段中。 

1:将float数组转化为char数组:

函数

输入:flaot一维数组  数组中包含个数n

输出:char一维数组

具体代码:

char *ptVal = new char[n*sizeof(float)];//用于存储转化得到的char数组

       for(int i = 0; i<n; i++)

       {  

              char *m = new char[sizeof(float)];

              float temp = f[i];//每次从float数组中取出一个对象

              memcpy(m,&temp,sizeof(float));//将float转化为一个4个字节的char数组 

              int j = 0;

        //将转化得到的char数组插入ptVal 数组的对应位置

              while (j<sizeof(float))

              {

                     ptVal[4*i+j] = m[j];

                     j++;

              }     

              delete m;

       }

 2:将char数组转化为safeArray数组类型,然后转化为BLOB数组类型并导入数据库

输入:char数组  数组对应字节数blobSize   数据库中对应字段的位置iCol

功能:将char数组转化为二进制并插入到数据库中

具体代码:

long i, rtn;

       char *pMove = NULL;

       _variant_t  vVal;

       SAFEARRAYBOUND  rgsabound[1];

       SAFEARRAY    *psa = NULL; 

       pMove = ptVal;

       //1. 创建SAFEARRAY对象

       rgsabound[0].lLbound = 0; //定义数组的下界

       rgsabound[0].cElements = blobSize; //定义数组元素的大小

       psa = SafeArrayCreate(VT_UI1,1,rgsabound); 

       for (i = 0; i < blobSize; i++)

       {

              if (FAILED(SafeArrayPutElement (psa, &i, pMove++)))

                     return (0);

       }

    //将数据存储为BLOB类型

       vVal.vt = VT_ARRAY | VT_UI1;

       vVal.parray = psa;

   //将二进制数据加入到数据库

       try

       {

              Fields   *pFields   =   m_pRecordset-> GetFields();

              Field   *pField   =   pFields-> GetItem( iCol);

              pField->AppendChunk(vVal);

       // m_pRecordset->GetFields()->GetItem(iCol)->AppendChunk(vVal); 

       }

     //捕捉错误

       catch (_com_error &e)

       {

              AfxMessageBox(e.Description());

              return(0);

       }

       return (1);

二:从数据库中取出数据

思路:从数据库中取出数据到一个char数组的缓冲区中,然后解码还原成float数组 

1:从数据库中取出数据到缓冲区中

 实现过程:   

     Fields *pFldS;

       pFldS = m_pRecordset ->GetFields();

       long lDataSize = pFldS->GetItem("Data")->ActualSize;

       _variant_t num = pFldS  ->GetItem("Num")->GetValue();

       int n = num.intVal;

       char *pBuf;

       if(fp!=NULL) delete fp;

       fp = new float[n];

       float test;

       if (lDataSize>0)

       {

              _variant_t val = pFldS->GetItem("Data")->GetChunk(lDataSize);

              if (val.vt == (VT_ARRAY|VT_UI1))

              {

                     pBuf = new char[lDataSize+1];

                     char *pMove = NULL;

                     SafeArrayAccessData(val.parray,(void **)&pMove);

                     memcpy(pBuf,pMove,lDataSize); //复制数据到缓冲区pBuf

                     SafeArrayUnaccessData(val.parray); 

从数据库中取出数据到float数组中:

实现过程:

       for(int i = 0; i<n; i++)

                     {  

                            char *m = new char[4]; 

                            int j = 0;

                            while (j<4)

                            {

                                   m[j] = pBuf[4*i+j] ;

                                   j++;

                            } 

                            memcpy(&test,m,4);

                            fp[i] = test;

                            delete m;

                     } 

                     delete [] pBuf;

              }

二进制数据库的存取

标签:

人气教程排行