• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            C語言實現myql中存取二進制文件

            最近搞mysql,這兩天想用C把二進制文件(<64k,大的就存儲路徑了)存儲到數據庫里,經過我不懈的搜索,發現NET上有且只有一個版本(php為例的),在C里根本行不通,我先是暈倒,醒了后我再搜索,還是php版本的,我又吐了一口血(之后又吐了好幾次)!最后還是在mysql手冊里找到了方向,是mysql_real_escape_string給了我光明,好了,不羅嗦了,不然要有礦泉水瓶砸過來了!為了不讓其它初學者吐血,我把我的code共享一下,希望大俠們指正,也歡迎雞蛋和西紅柿

            CODE:

             

            #include <stdio.h>
            #include <mysql/mysql.h>
            #include <stdlib.h>
            #include <sys/types.h>
            #include <sys/stat.h>
            #include <fcntl.h>

            #define host                "localhost"              //mysql server
            #define username        "root"
            #define password        "cipher"
            #define database         "www"
              
            int get_file_size(char *path, off_t *size)
            {
                    struct stat file_stats;

                    if(stat(path, &file_stats))
                            return -1;

                    *size = file_stats.st_size;
                    return 0;
            }
            int main(int argc, char *argv[])
            {
                    char  *filename;
                    off_t *size;

                    MYSQL            *conn;
                    MYSQL_RES    *res_set;
                    MYSQL_ROW    row;
                    MYSQL_FIELD *field;
                    int                    i, flag;
                    char                *sql;
                    FILE                *fp;
                    char                *buf;
                    int                    n=0;
                    char                *end;
                    unsigned long *length;       
                   
                    if (argc != 2) {
                            printf("Usage: %s srcfile\n", argv[0]);
                            exit(1);
                    }

                    filename = argv[1];
                    if ((get_file_size(filename, size)) == -1) {
                            perror("get file size" );
                            exit(1);
                    }
                   
                    if ((buf = (char *)malloc(sizeof(char)*(*size+1))) == NULL) {
                            perror("malloc buf" );
                            exit(1);
                    }

                    if ((fp = fopen(filename, "rb" )) == NULL) {
                            perror("fopen file" );
                            exit(1);
                    }

                    if ((n = fread(buf, 1, *size, fp)) < 0) {        //n=*size
                            perror("fread file" );
                            exit(1);
                    }

                    sql = (char *)malloc(sizeof(char)*n*2+256);        //2n+1+strlen(other sql)
                    if (sql == NULL) {
                            perror("malloc sql" );
                            exit(1);
                    }

                    conn = mysql_init(NULL);
                    if (conn == NULL) {
                            printf("init mysql, %s\n", mysql_error(conn));
                            exit(1);
                    }

                    if ((mysql_real_connect(conn, host, username, password, database, 0, NULL, 0)) == NULL) {
                            printf("connect mysql, %s\n", mysql_error(conn));
                            exit(1);
                    }

                    strcpy(sql, "insert into www(id, name, file) values(5, 'peter', " );
                    end = sql;
                    end += strlen(sql);                //point sql tail
                    //convert NUL(ASCII 0)
            '\n''\r''\'’''''"'Control-Z and so on
                    *end++ = '\'';
                    end += mysql_real_escape_string(conn, end, buf, n);
                    *end++ = '\'';
                    *end++ = ')';
                   
                    flag = mysql_real_query(conn, sql, (unsigned int)(end-sql));
                    if (flag != 0) {
                            printf("insert failed, %s\n", mysql_error(conn));
                            exit(1);
                    }

                    if ((mysql_real_query(conn, "SELECT file FROM www where id=5", 31)) != 0) {
                            printf("insert failed, %s\n", mysql_error(conn));
                            exit(1);
                    }
                    res_set = mysql_store_result(conn);

                    fclose(fp);
                    fp = NULL;

                    fp = fopen("foo.bk", "wb" );
                    while ((row = mysql_fetch_row(res_set)) != NULL) {
                            length = mysql_fetch_lengths(res_set);
                            for (i=0; i<mysql_num_fields(res_set); i++) {
                                    fwrite(row[0], 1, length[0], fp);
                            }
                    }

                    fclose(fp);
                    mysql_close(conn);
                    free(sql);
                    sql = NULL;
                   
                    return 0;
            }
            //gcc -o mysql_binary mysql_binary.c -lmysqlclient
            //usage: ./mysql_binary filename

            Makefile

            CODE:

            [Copy to clipboard]

            CXX = gcc
            LIBS = -lmysqlclient
            PRODUCT = mysql_binary
            .LIBPATTERNS: lib%.so lib%.a
            vpath %   .
            vpath %.c src
            vpath %.h include

            OBJS = mysql_binary.o
            $(PRODUCT): $(OBJS) 
                    $(CXX) $(OBJS) -o $@ $(LIBS)
            .c.o:

            .PHONY:clean
            clean:
                    -rm -f $(OBJS) $(PRODUCT)

            好了,擦汗!
            暈 這么多表情符號,弄一下。
            生成的foo.bk文件為源文件的拷貝

            posted on 2009-08-13 11:28 肥仔 閱讀(243) 評論(0)  編輯 收藏 引用 所屬分類: 數據庫

            99久久人人爽亚洲精品美女| 99久久做夜夜爱天天做精品| 99热成人精品热久久669| 国内精品久久久久久野外| 精品久久久无码中文字幕| 77777亚洲午夜久久多喷| 久久精品中文字幕久久| 亚洲国产精品成人久久蜜臀 | 久久人人添人人爽添人人片牛牛| 久久免费看黄a级毛片| 国产精品99久久不卡| 熟妇人妻久久中文字幕| 久久99精品九九九久久婷婷| 成人妇女免费播放久久久| 四虎影视久久久免费观看| 久久国产成人精品麻豆| 一本色道久久88精品综合 | 99国产欧美精品久久久蜜芽| 精品人妻伦一二三区久久| 精品综合久久久久久888蜜芽| 久久久久亚洲爆乳少妇无| 精品久久777| 久久精品99久久香蕉国产色戒 | 91久久九九无码成人网站| 国内精品伊人久久久久AV影院| 青青热久久国产久精品 | 久久久久亚洲AV无码麻豆| 精品久久人人爽天天玩人人妻| 久久嫩草影院免费看夜色| 色综合久久中文色婷婷| 久久被窝电影亚洲爽爽爽| 99久久99久久| 99久久精品免费观看国产| 99久久无码一区人妻a黑| 久久久久99精品成人片试看| 亚洲AV无码成人网站久久精品大| 一级a性色生活片久久无少妇一级婬片免费放| 久久国产精品免费| 97精品国产97久久久久久免费 | 99久久精品国产免看国产一区| 久久电影网一区|