c/c++ 获取mysql数据库以blob类型储存的图片

简单的code如下:

#include <iostream>
#include <fstream>
#include <sstream>
#include <cstring>
#include <mysql/mysql.h>
using namespace std;

int main()
{
    const char username[] = "username";
    const char password[] = "password";
    const char host[]   = "192.168.0.100";
    const char dbname[] = "dbname";

    MYSQL conn;
    if(NULL == mysql_init(&conn))
    {
        cerr << "init conn fail." << endl;
        exit(-1);
    }

    if (NULL == mysql_real_connect(&conn, host, username, password, dbname, 0, NULL, 0))
    {
        cerr << "connect to database error" << endl;
        exit(-1);
    }

    char sql[] = "select octet_length(picture), picture from tablename";
    if (0 != mysql_real_query(&conn, sql, strlen(sql)))
    {
        cerr << "query error." << endl;
        exit(-1);
    }

    MYSQL_RES * result = NULL;
    result = mysql_store_result(&conn);
    if (NULL == result)
    {
        cerr << "store result error." << endl;
        exit(-1);
    }

    if (0 >= mysql_affected_rows(&conn))
    {
        cerr << "no data be found." << endl;
        exit(-1);
    }

    int count = 0;
    string path = "/home/tsfh/pictures/";
    MYSQL_ROW row_record;
    while (row_record = mysql_fetch_row(result))
    {
        unsigned int size = 0;
        char * temp_buff = NULL;

        sscanf(row_record[0], "%d", &size);
        if(0 == size )
        {
            cerr << "invalid record!" << endl;
            continue;
        }

        temp_buff = (char *)malloc(size * sizeof(char) + 1);
        if(NULL == temp_buff)
        {
            cerr << "malloc error!" <<endl;
            exit(1);
        }
        memset(temp_buff, 0, size * sizeof(char) + 1);
        memcpy(temp_buff, row_record[1], size * sizeof(char));

        stringstream pic_name;
        pic_name << count << ".jpg";
        ofstream outfile(path + pic_name.str(), ios::binary);
        outfile.write(temp_buff, size);

        count++;
        free(temp_buff);
    }

    mysql_close(&conn);
    return 0;
}

 

转载于:https://www.cnblogs.com/tsfh/p/8877495.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值