使用SQLite数据库存取mp3和图片等二进制数据

前端之家收集整理的这篇文章主要介绍了使用SQLite数据库存取mp3和图片等二进制数据前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_502_0@ 源代码说话吧:

@H_502_0@ CString sql1 = "create table if not exists picture(id integer,pic blob)";
CString sql2 = L"insert into picture(id,pic)values(:id,:pic)";
CString sql3 = L"select * from picture";
pDB->BeginTrans();
pDB->Execute(_bstr_t(sql1));
pDB->CommitTrans();

@H_502_0@
FILE *fp;
LONG lfileSize = 0;
byte* picBuffer;
fp = fopen("./src.wma","rb");
if(NULL != fp)
{
fseek(fp,SEEK_END);
lfileSize = ftell(fp);
fseek(fp,SEEK_SET);
picBuffer = new byte[lfileSize];
size_t sz = fread(picBuffer,sizeof(byte),lfileSize,fp);
fclose(fp);
}

@H_502_0@CComSafeArray<byte> *pcsfa;
CComSafeArrayBound bound[1];
bound[0].SetCount(lfileSize);
bound[0].SetLowerBound(0);
pcsfa = new CComSafeArray<byte>(bound,1);
for(LONG i = 0; i <(LONG)lfileSize; i++)
{
HRESULT hr = pcsfa->SetAt(i,picBuffer[i]);
}

@H_502_0@_variant_t variant;
variant.vt = VT_ARRAY | VT_UI1;
variant.parray = pcsfa->m_psa;

@H_502_0@ISDKCommandPtr pCommand;
pCommand = pDB->CreateCommand();
pCommand->PrepareCommand(_bstr_t(sql2));
pCommand->BindParaByIndex(0,_variant_t(::GetCurrentThreadId()));
pCommand->BindParaByIndex(1,variant);
pCommand->Execute();

@H_502_0@ISDKResultSetPtr pResultSet;
pResultSet = pDB->Execute(_bstr_t(sql3));
cout << pResultSet->GetFieldCount() << endl;
cout << pResultSet->GetFieldName(1) << endl;

while(pResultSet->IsValidRow())
{
_variant_t val;
val = pResultSet->GetFieldValueByIndex(0);
int nId = val.lVal;
VariantClear(&val);

@H_502_0@val = pResultSet->GetFieldValueByName(_bstr_t(L"pic"));
LONG lfileSize2 = val.parray->rgsabound->cElements;
byte* buf = new byte[lfileSize2];
if(val.vt == (VT_UI1|VT_ARRAY))
{
for(LONG index = 0; index < lfileSize2; index++)
{
::SafeArrayGetElement(val.parray,&index,buf+index);
}
}
FILE *fp2;
fp2 = fopen("dest.wma","wb");
if(NULL != fp2)
{
size_t ret = fwrite(buf,lfileSize2,fp2);
fclose(fp2);
}
delete[] buf;
cout << endl;
VariantClear(&val);

@H_502_0@pResultSet->Next();
}
delete[] picBuffer;

@H_502_0@下面的是原始的API接口存取图片的示例代码

@H_502_0@sqlite3 *db;
sqlite3_stmt *stat,*stat2;
char *zErrMsg = 0;
FILE *fp = NULL;
long filesize = 0;
char * ffile = NULL;
char *buf = NULL;

@H_502_0@sqlite3_open("pic.db",&db);
if(db == NULL)
{
return -1;
}

@H_502_0@fp = fopen("inpic.jpg","rb");
if(fp != NULL)
{
fseek(fp,SEEK_END);
filesize = ftell(fp);
fseek(fp,SEEK_SET);

@H_502_0@ffile = new char[filesize];
size_t sz = fread(ffile,sizeof(char),filesize,fp);

@H_502_0@fclose(fp);
}

@H_502_0@sqlite3_exec(db,"create table pic (fliename varchar(128) unique,pic blob);",&zErrMsg);
sqlite3_prepare(db,"insert into pic values ('inpic.jpg',?)",-1,&stat,0);
sqlite3_bind_blob(stat,1,ffile,NULL);
sqlite3_step(stat);

@H_502_0@sqlite3_prepare(db,"select * from pic",&stat2,0);
sqlite3_step(stat2);
const void * picData = sqlite3_column_blob(stat2,1);
int size = sqlite3_column_bytes(stat2,1);
buf = new char[size];
sprintf(buf,"%s",picData);

@H_502_0@FILE*fp2;
fp2 = fopen("outpic.jpg","wb");
if(fp2 != NULL)
{
size_t ret = fwrite(picData,size,fp2);
fclose(fp2);
}

@H_502_0@delete[] ffile;sqlite3_finalize(stat);sqlite3_finalize(stat2);sqlite3_close(db);

猜你在找的Sqlite相关文章