zoukankan      html  css  js  c++  java
  • 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;
    }
  • 相关阅读:
    ASP.NET AJAX入门系列(1):概述
    ASP.NET中常用的文件上传下载方法
    Asp.net中DataBinder.Eval用法的总结
    ASP.NET AJAX入门系列(6):UpdateProgress控件简单介绍
    ASP.NET AJAX入门系列(8):自定义异常处理
    Javascrip常用语句
    26个常用的方法优化 ASP.NET 的性能
    JavaScript倒计时组件
    jQuery.buildFragment源码分析
    jQuery.Callbacks源码解读
  • 原文地址:https://www.cnblogs.com/tsfh/p/8877495.html
Copyright © 2011-2022 走看看