• <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)  編輯 收藏 引用 所屬分類: 數據庫

            亚洲中文久久精品无码ww16| 亚洲乱亚洲乱淫久久| 久久精品中文字幕大胸| 久久亚洲美女精品国产精品| 青青草原综合久久| 久久亚洲国产最新网站| 久久久精品人妻一区二区三区四| 欧美一区二区精品久久| 亚洲午夜久久久久久噜噜噜| 久久播电影网| 国内精品久久久久| 成人综合久久精品色婷婷| 国产精品国色综合久久| 国产成人综合久久精品红| 久久精品国产精品亜洲毛片| 国产综合久久久久| 中文字幕无码精品亚洲资源网久久| 狠狠色噜噜狠狠狠狠狠色综合久久 | 精品一区二区久久| 久久久久久精品免费看SSS| 九九热久久免费视频| 国产91久久精品一区二区| 久久综合给合久久狠狠狠97色| 超级97碰碰碰碰久久久久最新| 国产精品激情综合久久| 国产精品久久久久影院色| 少妇内射兰兰久久| 久久天天躁狠狠躁夜夜网站| 香蕉久久av一区二区三区| 久久综合狠狠综合久久综合88| 波多野结衣久久一区二区| 午夜精品久久久内射近拍高清 | 久久人妻少妇嫩草AV蜜桃| 9191精品国产免费久久| 中文字幕久久欲求不满| 精品久久久久中文字| 久久久不卡国产精品一区二区| 久久久久国产精品麻豆AR影院 | 久久精品成人欧美大片| 亚洲午夜无码久久久久| 久久精品午夜一区二区福利|