日期:2014-05-16 浏览次数:20604 次
转自?
http://www.oschina.net/question/12_7956
 ? 先安装MySQL? 再装开发包? 可以用以下代码测试一下 ? ? 我试了一下,提示找不到mysql.h。 方法二:gcc test.c -o test -L/user/lib/mysql -lmysqlclient??????????????? 成功! 方法三:gcc test.c -o test $(mysql_config --cflags) $(mysql_config --libs) 或者:gcc test.c -o test $(mysql_config --cflags --libs)??????????????????????? 成功! ---------------------------------------------------------------------------------------- 以上是转贴,这里说下我自己遇到的问题: 1. mysql.h 的文件路径是/usr
/lib/mysql 而不是 /user
/lib/mysql, 2. 声明为include <mysql/mysql.h>,编译时就不报错了。
代 码:?
sudo apt-get install mysql-server mysql-client
代码:?
sudo apt-get install libmysqlclient15-dev/* 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);
} 
编译:
方法一:gcc test.c -o test -I/user/include/mysql?????????????????????????????? 试了一下,提示找不到mysql.h。
分析:
/user/include/mysql:全是.h文件,应该应编译阶段
/user /lib/mysql:是静态库和动态库,www.linuxidc.com应该与上面的.h文件对应,用于连接阶段。