• <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

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見(jiàn)諒!~
            隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            C語(yǔ)言實(shí)現(xiàn)myql中存取二進(jìn)制文件

            最近搞mysql,這兩天想用C把二進(jìn)制文件(<64k,大的就存儲(chǔ)路徑了)存儲(chǔ)到數(shù)據(jù)庫(kù)里,經(jīng)過(guò)我不懈的搜索,發(fā)現(xiàn)NET上有且只有一個(gè)版本(php為例的),在C里根本行不通,我先是暈倒,醒了后我再搜索,還是php版本的,我又吐了一口血(之后又吐了好幾次)!最后還是在mysql手冊(cè)里找到了方向,是mysql_real_escape_string給了我光明,好了,不羅嗦了,不然要有礦泉水瓶砸過(guò)來(lái)了!為了不讓其它初學(xué)者吐血,我把我的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)

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

            posted on 2009-08-13 11:28 肥仔 閱讀(240) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)庫(kù)

            久久免费看黄a级毛片| 精品久久久久久成人AV| 精品免费久久久久国产一区| 久久精品国产亚洲7777| 亚洲国产另类久久久精品小说| 久久不见久久见免费视频7| 久久成人18免费网站| 日本久久久久久久久久| 99久久精品国内| 久久久无码精品亚洲日韩按摩| 亚洲国产另类久久久精品小说| 韩国三级大全久久网站| 久久久久成人精品无码中文字幕| 国内精品人妻无码久久久影院 | 久久久久亚洲国产| 久久精品无码专区免费青青 | 国产偷久久久精品专区| 国产精自产拍久久久久久蜜| 久久久久亚洲av无码专区| 蜜桃麻豆www久久| 久久99国产精一区二区三区| 久久最新免费视频| 四虎久久影院| 91精品国产91久久久久久蜜臀| 久久久噜噜噜久久熟女AA片| 久久久久国产精品三级网| 亚洲人成伊人成综合网久久久| 国产精品va久久久久久久| 久久久亚洲欧洲日产国码二区| 日韩欧美亚洲综合久久| 久久久久久久久久久| 精品久久国产一区二区三区香蕉| 人人狠狠综合久久88成人| 久久精品国产99久久久| 久久精品一区二区三区AV| 日批日出水久久亚洲精品tv| 99久久综合狠狠综合久久| 久久精品www人人爽人人| 人妻少妇久久中文字幕| 亚洲狠狠婷婷综合久久蜜芽| 久久精品极品盛宴观看|