mysql sql blob查询_mysql blob数据的插入与查询

举例将一个本地图片读入到mysql里面的表字段  msg_body,这个字段为blob类型,并将该数据查询并写入到一个图片

代码如下:连接mysql省略,只列重点:

插入数据到表里面,

FILE*imgP;

fopen_s(&imgP,"gj_hover.png","rb");//这里是用二进制读取,read-r;binary-b;因为只弄r结果出错!!弄了后面那个的再来看这个才发现是这个的问题!!

if (imgP == NULL)return ;

fseek(imgP, 0L, SEEK_END);

long size = ftell(imgP);

byte*imgbuf = new byte[size+ 1];

fseek(imgP,0x0L,SEEK_SET);//图片源

fread(imgbuf, sizeof(imgbuf[0]), size, imgP);

const char *szSQL = "insert into msg_info(id,msg_body,date_add) values(?,?,?)";

char id[20]="1";

char date_add[22]={"2017-05-08 12:12:12"};

MYSQL_BIND db[3];

memset(db,0,sizeof(db));

db[0].buffer_type=MYSQL_TYPE_STRING;

db[0].buffer=id;

db[0].buffer_length=strlen(id);

db[0].is_null= 0;

db[0].length= 0;

db[1].buffer_type=MYSQL_TYPE_BLOB;

db[1].buffer=imgbuf;

db[1].buffer_length=size+1;

db[1].is_null= 0;

db[1].length= 0;

db[2].buffer_type=MYSQL_TYPE_STRING;

db[2].buffer=date_add;

db[2].buffer_length=strlen(date_add);

db[2].is_null= 0;

db[2].length= 0;

if (!m_lpDBModule.Execute(szSQL,db))

{

MessageBox(L"insert failer!");

return ;

}

fclose(imgP);

查询数据并写入到图片:

BOOL CMySqlDriver::GetData(const char* szSQL)

{

if (!m_pMySQL)

{

return FALSE;

}

MYSQL_STMT* pSmt = mysql_stmt_init(m_pMySQL);

if (!pSmt)

{

m_szError = mysql_error(m_pMySQL);

return FALSE;

}

int nRet = mysql_stmt_prepare(pSmt,szSQL,strlen(szSQL));

if (nRet != 0)

{

m_szError = mysql_stmt_error(pSmt);

mysql_stmt_close(pSmt);

return FALSE;

}

MYSQL_BIND result = {0};

unsigned long total_length = 0;

result.buffer_type = MYSQL_TYPE_BLOB;

result.length = &total_length;

nRet = mysql_stmt_bind_result(pSmt, &result);

assert(0==nRet);

nRet = mysql_stmt_execute(pSmt);

assert(0==nRet);

nRet = mysql_stmt_store_result(pSmt);

assert(0==nRet);

for (;;)

{

nRet = mysql_stmt_fetch(pSmt);

if (nRet!=0 && nRet!=MYSQL_DATA_TRUNCATED) break;

int start = 0;

char *buf=new char[total_length];

memset(buf,0,sizeof(buf));

printf("total_length=%lu\n", total_length);

while (start

{

result.buffer = (buf+start);

result.buffer_length = 3;  //每次读这么长

nRet = mysql_stmt_fetch_column(pSmt, &result, 0, start);

if (nRet!=0)

{

return FALSE;

}

start += result.buffer_length;

}

CFile f;

if(!f.Open(L"D:\\work\\testbigdata\\test.png", CFile::modeCreate|CFile::modeWrite | CFile::typeBinary))

{

return FALSE;

}

f.Write(buf,total_length);

f.Flush();

f.Close();

}

mysql_stmt_close(pSmt);

return TRUE;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值