EzDoum

찾기
처음으로 | 찾기 | 아카이브 | 글 올리기 | 링크 | 자료실 | 통계 | 연락처 | 자유게시판
이지도움 특집
전체보기
네트워크
TI OMAP35x
TI DaVinci
Analog Blackfin
RobotWar2005
임베디드!
캐쉬의 모든것
메모리 할당 알고리즘
CPU 파이프라이닝
자료구조(Tree)
금융

Login
이름

암호

기억하기


사용자 등록

현재 접속중인 등록 사용자는 0명, 익명 사용자는 1명 입니다.
전체 등록 사용자: 751명

마지막 답장
·libcurl + fuse 조합으로 되는게 많네. (1)
·Linux Ftrace에 관해 (3)
·Android MTP ( Media Transfer Protocol ) (1)
·Lighttpd에 인증을 digest 사용시 IE 오동작 문제? (1)
·Dtrace에 관해 (1)

최근글
·OpenSSL and multi-threads (0)
·ARM 환경에서 OpenCL 사용 (0)
·IoT용 WIFI 모듈 비교 ( MCU ) 클래스 (0)
·Glances - 리눅스 여러 가지 항목을 한 화면에서 모니터링 (0)
·plugin 방식의 로그 분석기 (0)

뜨거운 감자
·나는 인터렉티브한 환경에서 역어셈블 한다. (12)
·GNU REGEX (정규표현식) 프로그래밍 강좌 (7)
·SoCRobotWar 2005 - 신입생 기초 교육자료 (7)
·ASP.NET의 데이터 그리드와 사용자 컨트롤 (7)
·DHTML Editing Control (7)

가장 많이 읽은 글
·[Cache] 2-way Set-Associative 방식이란 무엇일까? (2)
·멀티쓰레드(Pthread) 프로그래밍
·GNU REGEX (정규표현식) 프로그래밍 강좌 (7)
·Sorting Algorithm Animation (2)
·SoCRobotWar 2005 - 신입생 기초 교육자료 (7)

Mysql C API 관련 자료
글쓴이: EzDoum 글쓴날: 2003년 04월 07일 오후 02:42
리눅스



mysql 메뉴얼에 제공되는 c api관련 내용이 너무 부실해서, 다른 자료를 좀 찾아 봤습니다.

그러던중 책을 하나 발견했는데, 그 책의 샘플챕터를 마침 c api에 관한 부분을 해주더군요.

MySQL, Second Edition by Paul DuBois
http://www.amazon.com/exec/obidos/ASIN/0735712123/ref=ase_kitebird-20/103-6369375-7987024

책소개 사이트에서 받아논 샘플 챕터 입니다.
http://www.kitebird.com/mysql-book/

  • 첨부 파일: ch06-2ed.pdf ch06-2ed.pdf (288 KiB(295,065 Bytes))

  • 관련 링크
  • [분류: 리눅스 인쇄용 페이지 본문 email로 보내기 ]

    <  define으로 해결하는 C 자료구조 | 국전&용산 중고 소프트 매매 기행기  >
    Mysql C API 관련 자료 | 답장: 2개 | 본문에 답장
    정렬 :  
    답장 EzDoum 2003년 04월 07일 오후 10:44 [ 이글에 답장 | 본문에 답장 | 책갈피 ]
    Executing SQL statements in MySQL databases using C
    Excerpt from Professional Linux Programming

    http://www-106.ibm.com/developerworks/linux/library/l-sql.html?dwzone=linux#h5
    http://www.ezdoum.com/upload/2/20030407144225/mysql.c.api.pdf


    [수정]

    답장 EzDoum 2003년 04월 07일 오후 10:59 [ 이글에 답장 | 본문에 답장 | 책갈피 ]
    Storing a BLOB in a MySQL database with the MySQL C API
    
    --------------------------------------------------------------------------------
    
    From: Stephane Wirtel 
    Subject: Storing a BLOB in a MySQL database with the MySQL C API 
    Date: Sun, 02 Feb 2003 12:56:37 -0800 
    
    --------------------------------------------------------------------------------
    
    Hi all !
    
    I would like to insert a Blob ( a picture exactly ), here is a small
    source code to test my insert.
    You can find 2 sources code, the first is to insert a blob in a table of
    a database ( this database exists in my MySQL server )
    
    And the second code is to read this blob from the database.
    
    I think there are a lot of mistakes, could you help me ? because i did
    not find the solution.
    
    thanks
    
    
    #include <mysql/mysql.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <unistd.h>
    #include <sys/stat.h>
    #include <fcntl.h>
    #include <glib.h>
    
    int main(int argc, char **argv)
    {
    MYSQL *mysql = NULL;
    struct stat statbuf;
    int file;
    unsigned long size, ssize;
    gchar *data = NULL, *query = NULL, *end = NULL;
    int i;
    	mysql = (MYSQL *) g_malloc0(sizeof(MYSQL));
    	mysql_init(mysql);
    	mysql = mysql_real_connect(mysql, "localhost","test", "XXXX","test_stef", 0, NULL, 0);
    	file = open("photo.png", O_RDONLY);
    	//file = open("test_mozilla.c", O_RDONLY);
    	if ( !file )
    		g_error("Impossible d'ouvrir le fichier photo.png");
    	fstat(file, &statbuf);		
    	fprintf(stdout, "Size of photo.png : %ld\n", statbuf.st_size);
    	size = statbuf.st_size;
    	
    	data = (gchar *) g_malloc0(size);
    	if ( !data )
    		g_error("Impossible de charger la memoire requise");
    	ssize = read(file, data, size);
    	if ( ssize == size )
    		g_message("Fichier correctement lu");
    	query = (gchar *) g_malloc0(2*size);
    	strcpy(query, "INSERT INTO test VALUES(");
    	end = query + strlen(query);
    	*end++ = '\'';
    	gchar * debut, *fin;
    	debut = end;
    	end += mysql_real_escape_string(mysql, end, data, size);
    	fin = end;
    	fprintf(stdout, "Difference : %lu\n",(unsigned long) (fin - debut));
    	*end++ = '\'';
    	*end++ = ')';
    
    	/*for ( i = 0 ; i < 30 ; i++ )
    		fprintf(stdout, "%c", query[i]);*/
    	if ( mysql_real_query(mysql, query, (unsigned long) ( end - query )) )
    	{
    		g_error("Erreur lors de la requete d'insertion dans la DB");
    	}
    	g_free(data);   
    	g_free(query);
    	mysql_close(mysql);
    	return 0;
    }
    
    But when i edit the mysql database with mysqlcc utility, i don't the
    complete file.
    
    now, when i read the Blob from the database, i use this source code.
    
    #include <glib.h>
    #include <mysql/mysql.h>
    #include <stdio.h>
    #include <string.h>
    #include <stdlib.h>
    
    int main(int argc, char **argv)
    {
    MYSQL *mysql = NULL;
    MYSQL_RES *mysql_res = NULL;
    MYSQL_FIELD *mysql_field = NULL;
    MYSQL_ROW *mysql_row = NULL;
    	gchar query[] = "SELECT photo FROM test";
    	mysql = (MYSQL *) g_malloc(sizeof(MYSQL));
    	mysql_init(mysql);
    
    	if( !mysql_real_connect(mysql, "localhost", "test", "XXXX", "test_stef", 0, NULL, 0) )
    		g_error("Failed to connect to database : Error : %s\n", mysql_error(mysql));
    	
    	if (mysql_real_query(mysql, query, strlen(query)))
    		g_error("Failed query to database : Error : %s\n", mysql_error(mysql));
    
    	if ( !(mysql_res = mysql_store_result(mysql)) )
    		g_error("Failed Store Result : Error : %s\n", mysql_error(mysql));
    	
    	mysql_field = mysql_fetch_field(mysql_res);
    	g_print("Field name : %s\n", mysql_field->name);
    
    	mysql_row = mysql_fetch_row(mysql_res);
    	FILE *fichier;
    	fichier = fopen("photo_2.png", "wb");
    	fwrite(mysql_row[0], strlen(mysql_row[0]), 1, fichier);
    	fclose(fichier);
    	mysql_close(mysql);
    	g_free(mysql);
    	return 0;
    }
    
    Thanks
    
    Stephane Wirtel
    
    
    ---------------------------------------------------------------------
    Before posting, please check:
       http://www.mysql.com/manual.php   (the manual)
       http://lists.mysql.com/	   (the list archive)
    
    To request this thread, e-mail <mysql-thread131460@lists.mysql.com>
    To unsubscribe, e-mail <mysql-unsubscribe-archive=jab.org@lists.mysql.com>
    Trouble unsubscribing? Try: http://lists.mysql.com/php/unsubscribe.php
    

    [수정]

    Mysql C API 관련 자료 | 답장: 2개 | 본문에 답장
    정렬 :  

    답장 쓰기
    글을 올리시려면 로그인 (사용자 등록) 하셔야 합니다.

    검색
    Google

    분류
    ·공지 (6)
    ·인터넷 (87)
    ·하드웨어 (260)
    ·C/C++ (65)
    ·어셈블리 (7)
    ·리눅스 (136)
    ·리눅스 커널 (67)
    ·윈도우즈 (25)
    ·데이터베이스 (20)
    ·보안 (16)
    ·.NET (25)
    ·그래픽 (13)
    ·책소개 (42)
    ·호기심 천국 (80)
    ·잡담 (111)
    ·사랑 (3)

    전체 본문수: 963
    전체 답장수: 525


    분류 : 리눅스
    최근글
    최근글
    가장 많이 읽은 글
    ·멀티쓰레드(Pthread) 프로그래밍 (0)
    뜨거운 감자
    ·GNU REGEX (정규표현식) 프로그래밍 강좌 (7)

    EzDoum투표
    이지도움 어때요?
    이게 뭐야. 다시 안올란다. --;
    아이 좋아라~ +_+;
    관심없다.
    먼가는 있는거 같은데 뭐하는 곳이지?
    기타 (자유게시판에 글로 남겨 주세요)
    [ 결과 | 투표 ]

    랜덤 링크
    http://kldp.net


     Home ^ BACK TO TOP ^ EzDoum - 도움이 필요하세요~??
     Powered by KorWeblog 1.5.8 Copyleft © 2001 EzDoum, 관리자: EzDoum