40

我正在尝试在 ubuntu 12.04 中安装 c++ 和 mysql 之间的连接。我已经安装了 mysql-client、mysql-server、libmysqlclient15-dev、libmysql++-dev。但是当我尝试编译代码时出现错误:mysql.h there is no such file。我查看了文件夹,有 mysql.h 文件,我不明白为什么找不到它。这是我的代码:

 /* 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";
      //set the password for mysql server here
      char *password = "*********"; /* set me first */
      char *database = "Real_flights";

      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);
    }

它有效,但现在我面临另一个错误,例如:

mysql.c: In function ‘main’:
mysql.c:21: warning: incompatible implicit declaration of built-in function ‘exit’
mysql.c:27: warning: incompatible implicit declaration of built-in function ‘exit’
/tmp/ccinQBp8.o: In function `main':
mysql.c:(.text+0x3e): undefined reference to `mysql_init'
mysql.c:(.text+0x5e): undefined reference to `mysql_real_connect'
mysql.c:(.text+0x70): undefined reference to `mysql_error'
mysql.c:(.text+0xa5): undefined reference to `mysql_query'
mysql.c:(.text+0xb7): undefined reference to `mysql_error'
mysql.c:(.text+0xe7): undefined reference to `mysql_use_result'
mysql.c:(.text+0x11c): undefined reference to `mysql_fetch_row'
mysql.c:(.text+0x133): undefined reference to `mysql_free_result'
mysql.c:(.text+0x141): undefined reference to `mysql_close'
collect2: ld returned 1 exit status
4

9 回答 9

60

mysql.h来自Ubuntu 软件包的文件libmysqlclient-dev位于/usr/include/mysql/mysql.h.

然而,这不是编译器的标准搜索路径/usr/include

您通常会mysql.h像这样在代码中使用标头:

#include <mysql/mysql.h>

如果您不想在源代码中指定目录偏移量,则可以将-I标志传递给 gcc(如果这是您正在使用的)以指定额外的包含搜索目录,然后您就不需要更改现有代码.

例如。

gcc -I/usr/include/mysql ...
于 2013-01-30T13:00:13.623 回答
36

只需使用

$ apt-get install libmysqlclient-dev 

它将自动拉取最新的 libmysqlclient18-dev

我见过旧版本的 libmysqlclient-dev(如 15)将 mysql.h 放在奇怪的位置,例如 /usr/local/include 等。

否则,只需做一个

$ find /usr/ -name 'mysql.h' 

并将mysql.h带有 -I 标志的文件夹路径放入您的制作文件中。不干净,但会工作。

于 2013-12-17T12:42:15.973 回答
18

对于 CentOS/RHEL:

yum install mysql-devel -y
于 2014-03-21T18:27:48.620 回答
5

这对我有用

$ gcc dbconnect.c -o dbconnect -lmysqlclient
$ ./dbconnect

-lmysqlclient 是必须的。

我建议使用以下符号而不是使用 -I 编译标志。

#include <mysql/mysql.h>
于 2020-05-13T07:50:00.783 回答
3

在我认为的几个 unix 系统上,您可能没有包含 mysql 标头的路径,该路径可以在 /usr/include/mysql 中找到。看看这个帖子,可能会有帮助。

顺便说一句,与上面那个人的问题有关,关于合成配置。可以将以下内容添加到您的 ~/.vimrc 中:

let b:syntastic_c_cflags = '-I/usr/include/mysql'

您可以随时查看github 上开发人员的wiki 页面。享受!

于 2015-03-25T23:00:37.897 回答
2

您必须让编译器知道在哪里可以找到 mysql.h 文件。这可以通过在编译之前给出头文件的路径来完成。在 IDE 中,您有一个设置,您可以在其中提供这些路径。

链接为您提供有关编译时使用哪些选项的更多信息。

对于第二个问题 ,您需要链接库。链接器需要知道库文件在哪里,哪些是您使用的 mysql 函数的实现。

链接为您提供有关如何链接库的更多信息。

于 2013-01-30T12:44:45.863 回答
2

我想你可以试试这个 gcc -I/usr/include/mysql * .c -L/usr/lib/mysql -lmysqlclient -o *

于 2014-03-04T00:17:34.590 回答
1

这对我有用

yum install mysql

它将安装mysql客户端,然后

pip install mysqlclient
于 2021-02-15T10:30:42.233 回答
1

对于那些正在使用Eclipse IDE 的人。

将完整的 MySQL 与mysql 客户端mysql 服务器以及任何mysql 开发库一起安装后,

您需要告诉Eclipse IDE以下内容

  • 在哪里可以找到mysql.h
  • 在哪里可以找到libmysqlclient
  • 搜索libmysqlclient库的路径_ _

这是你如何去做的。

添加mysql.h

1 . GCC C编译器->包含->包含路径(-l)然后单击+并添加路径到你的mysql.h在我的例子中是/usr/include/mysql

在此处输入图像描述

要将mysqlclient库和搜索路径添加到mysqlclient库的位置,请参见步骤34

2 . GCC C Linker -> Libraries -> Libraries(-l) 然后点击+并添加mysqlcient

在此处输入图像描述

3 . GCC C Linker -> Libraries -> Library search path (-L) 然后点击+并将搜索路径添加到mysqlcient。就我而言,它是/usr/lib64/mysql因为我使用的是64 位 Linux 操作系统64 位 MySQL数据库。

否则,如果您使用的是32 位 Linux 操作系统,您可能会发现它位于/usr/lib/mysql

在此处输入图像描述

于 2019-04-16T10:26:47.253 回答