C语言写二进制数据到mysql的Blob字段

-- 引子--

  由于调试需要,需直接往数据库里写入二进制数据。本来这些数据是由上层软件来写的,用的是C#。为了熟悉C语言的数据库操作,还是决定用C来写这段调试代码。

概况:

  表名:Task

  涉及的字段及属性:

       NumDest:int(11)  用于存储目标数目

       destIDs:   blob        用于存储具体的目标ID

废话不多说,入正题。

--二进制数据写入--

  二进制数据最为常见的就是图片等一些文件信息。虽然我这里不是这类型信息,但确实是二进制数据。

  具体步骤:

1、  定义一个buffer(如数组)来存储sql语句

2、  把涉及到二进制数据之前的sql语句添加到buffer中,可用sprintf或strcpy等。

3、  用mysql_real_escape_string()函数添加二进制数据到buffer中。

4、  加上剩余的sql语句,形成完整的sql语句。

5、  利用mysql_real_query()函数来执行sql语句。

具体代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <mysql/mysql.h>
#include <stdint.h>
#include <string.h>

int main(int argc, char *argv[])
{
    MYSQL mysql;
    char sql[256], *end;
    int index, i;
    uint32_t *destIDs;

    if(argc != 2)
    {
        printf("enter error!\n");
        exit(1);
    }
    index = atoi(argv[1]);
    printf("index: %d\n", index);
    destIDs = (uint32_t *)malloc(index * sizeof(uint32_t));
    if(destIDs == NULL)
        printf("malloc error\n");
    for(i=0; i<index; i++)
        destIDs[i] = i + 1;
mysql_init(&mysql);
    if(!(mysql_real_connect(&mysql, "localhost", "root", "654321", "dbname", 0, NULL, 0)))
    {
        fprintf(stderr, "Couldn't connect to engine!\n%s\n", mysql_error(&mysql));
        perror("");
        exit(1);
    }
    
    sprintf(sql, "INSERT INTO Task(NumDest, DestIDs) VALUE (%u, ", index );
    end = sql + strlen(sql);
    *end++ = '\'';
    end += mysql_real_escape_string(&mysql, end,(char *)destIDs, index*sizeof(uint32_t));
    *end++ = '\'';
    *end++ = ')';

    printf("end - sql: %d\n", (unsigned int)(end - sql));

    if(mysql_real_query(&mysql, sql, (unsigned int)(end - sql)))
    {
        fprintf(stderr, "Query failed (%s)\n", mysql_error(&mysql));
        exit(1);
    }
mysql_close(&mysql);
    exit(0);
#endif
    return 0;
}

显示详细信息

--读取二进制文件--

对于二进制文件的读取,也类似。

具体步骤:

    1,构造查询字串.

2,执行mysql _query查询. (网上有说用mysql_real_query,未实验)

3,用mysql_store_result存储结果.

4,用mysql_fetch_row取出一条记录处理.

具体代码如下:

 
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <mysql/mysql.h>
#include <string.h>

int main(void)
{
    int ret, i;
    char sql[256];
    MYSQL mysql;
    MYSQL_RES *result;
    MYSQL_ROW row;
    uint32_t *destIDs, *temp;
    unsigned int destNum = 0;

    mysql_init(&mysql);
    if(!(mysql_real_connect(&mysql, "localhost", "root", "654321", "dbname", 0, NULL, 0)))
    {
        fprintf(stderr, "Couldn't connect to engine!\n%s\n",
                mysql_error(&mysql));
                perror("");
                exit(1);
    }

    sprintf(sql,
            "SELECT TaskID, NumDest, DestIDs FROM Task");
    ret = mysql_query(&mysql, sql);
    if(ret != 0)
    {
        printf( "Failed to query task table: %s\n",
                mysql_error(&mysql));
        return ret;
    }

    result = mysql_store_result(&mysql);
    if(result == NULL)
    {
        ret = mysql_errno(&mysql);
        printf( "Failed to store query result from task table:%s\n",
                mysql_error(&mysql));
        return ret;
    }

    if((row = mysql_fetch_row(result)) != NULL)
    {
        sscanf(row[1], "%u", &destNum);

        destIDs = (uint32_t *)malloc(destNum * sizeof(uint32_t));
        if(destIDs == NULL)
        {
            printf("malloc error!\n");
            exit(1);
        }
        memcpy(destIDs, row[2], destNum * sizeof(uint32_t));   
    }

    mysql_free_result(result);

    printf("destNum: %d\n", destNum);
    temp = destIDs;
    for(i=0; i<destNum; i++)
    {
        printf("destIDs[%d]:%d\t", i+1, *temp++);
    }

    return ret;
}
显示详细信息
 

由于我这里可以根据NumDest获取到二进制的长度,所以不用再用函数去获取。

据网上信息,获取二进制信息长度应该这样:“如果取出来的是二进制的数据,要确定它的长度,必须要用mysql_fetch_lengths函数取得其长度”

 
int num_fields = mysql_num_fields(result);
        unsigned long *lengths = mysql_fetch_lengths(result);
        for(i=0; i<num_fields; i++)
            printf("Column: %u\t %lu bytes\n", i+1, lengths[i]);
        destIDs = (uint32_t *)malloc(lengths[2]);
        if(destIDs == NULL)
        {
            printf("malloc error!\n");
            exit(1);
        }
        memcpy(destIDs, row[2], lengths[2]);



才疏学浅,欢迎拍砖!
参考资源:
http://djy0011.blog.163.com/blog/static/138197453201083054918451/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值