安装mysql 获得 mysql.h 建立C接口

今天费了好长时间终于让C操作MYSQL成功了,在此把方法记下来,留着以后用。hoho~ 
先安装mysql 
代码: 
sudo apt-get install mysql-server mysql-client 

再装开发包 
代码: 
sudo apt-get install libmysqlclient15-dev 

安装完以后,C代码里添加头文件 
代码: 
#include <mysql.h> 

编译方法: 
代码: 
gcc $(mysql_config --cflags) xxx.c -o xxx $(mysql_config --libs) 


可以用以下代码测试一下 
代码:

C代码 
  1. /* Simple C program that connects to MySQL Database server*/   
  2. #include <mysql.h>   
  3. #include <stdio.h>   
  4.   
  5. main() {   
  6.      MYSQL *conn;   
  7.      MYSQL_RES *res;   
  8.      MYSQL_ROW row;   
  9.   
  10.    char *server = "localhost";   
  11.    char *user = "root";   
  12.    char *password = ""; /* 此处改成你的密码 */   
  13.    char *database = "mysql";   
  14.   
  15.      conn = mysql_init(NULL);   
  16.   
  17.    /* Connect to database */   
  18.    if (!mysql_real_connect(conn, server,   
  19.            user, password, database, 0, NULL, 0)) {   
  20.        fprintf(stderr, "%s\n", mysql_error(conn));   
  21.        exit(1);   
  22.     }   
  23.   
  24.    /* send SQL query */   
  25.    if (mysql_query(conn, "show tables")) {   
  26.        fprintf(stderr, "%s\n", mysql_error(conn));   
  27.        exit(1);   
  28.     }   
  29.   
  30.      res = mysql_use_result(conn);   
  31.   
  32.    /* output table name */   
  33.     printf("MySQL Tables in mysql database:\n");   
  34.    while ((row = mysql_fetch_row(res)) != NULL)   
  35.        printf("%s \n", row[0]);   
  36.   
  37.    /* close connection */   
  38.      mysql_free_result(res);   
  39.      mysql_close(conn);   
  40. }   
/* Simple C program that connects to MySQL Database server*/ #include <mysql.h> #include <stdio.h> main() { MYSQL *conn; MYSQL_RES *res; MYSQL_ROW row; char *server = "localhost"; char *user = "root"; char *password = ""; /* 此处改成你的密码 */ char *database = "mysql"; conn = mysql_init(NULL); /* Connect to database */ if (!mysql_real_connect(conn, server, user, password, database, 0, NULL, 0)) { fprintf(stderr, "%s\n", mysql_error(conn)); exit(1); } /* send SQL query */ if (mysql_query(conn, "show tables")) { fprintf(stderr, "%s\n", mysql_error(conn)); exit(1); } res = mysql_use_result(conn); /* output table name */ printf("MySQL Tables in mysql database:\n"); while ((row = mysql_fetch_row(res)) != NULL) printf("%s \n", row[0]); /* close connection */ mysql_free_result(res); mysql_close(conn); }

会输出现有数据库和表内容。

你可能感兴趣的:(c,mysql,server,null,database,query)