CLion Cmake mysql.h误解

时间:2017-10-15 19:50:04

标签: c++ mysql c++11 cmake clion

我是c ++开发的新手。    我想尝试使用MySQL数据库,但无法理解它的错误。这是我的代码。

    #include <iostream>
    #include <mysql.h>
    MYSQL *connection, mysql;
    MYSQL_RES *result;
    MYSQL_ROW row;
    int query_state;

    int main() {
        mysql_init(&mysql);
        //connection = mysql_real_connect(&mysql,"host","user",
        //                   "password","database",port,"unix_socket",clientflag);
        connection = mysql_real_connect(&mysql,"localhost",
                                        "root","qwer","cpp_data",3306,0,0);
        if (connection == NULL) {
            std::cout << mysql_error(&amp;mysql) << std::endl;
            return 1;
        }

        query_state = mysql_query(connection, "select user_count()");
        if (query_state !=0) {
            std::cout << mysql_error(connection) << std::endl;
            return 1;
        }

        result = mysql_store_result(connection);
        while (( row = mysql_fetch_row(result)) != NULL) {
            std::cout << "Number of active users : " << row[0] << std::endl;
        }

        mysql_free_result(result);
        mysql_close(connection);

        return 0;
    }

当我运行我的程序时,它说 C:\ Users \ user \ CLionProjects \ my-cpp-training \ main.cpp:9:19:致命错误:mysql.h:没有这样的文件或目录

我将提供我的CMakeList,还有一些我通过学习写的来源。这是:

cmake_minimum_required(VERSION 3.8)
project(my_cpp_training)

set(CMAKE_CXX_STANDARD 11)

LINK_DIRECTORIES(D:/Downloads/mysql-connector-c++-noinstall-1.1.9-winx64/include)
include_directories ("D:/Downloads/mysql-connector-c++-noinstall-1.1.9-winx64/include")

set(SOURCE_FILES main.cpp util/ContrainerUtils.cpp classes/Examples.cpp classes/Person.cpp classes/Person.h pointers/PointersArithmatic.cpp classes/Object.cpp classes/Object.h classes/Animal.cpp classes/Animal.h classes/Vector.cpp classes/Vector.h bussiness-layer/user.cpp util/Out.cpp util/Out.h classes/Container.cpp classes/Container.h classes/Vector_container.cpp classes/Vector_container.h util/PropertiesReader.cpp util/PropertiesReader.h util/Settings.cpp util/Settings.h)
add_executable(my_cpp_training ${SOURCE_FILES})
target_link_libraries (my_cpp_training mysqlcppconn)

在这里,我将展示我在我的计算机上通过我在CMakeList.txt中使用的路径下载和提取的库

path to mysql c++ library

请帮助我,不仅仅是想写下你的想法,我已经用谷歌搜索了半天,并阅读了很多东西。只是写在这里就像你不正确,或者你忘了这段代码或行。

1 个答案:

答案 0 :(得分:0)

理查德霍奇斯是对的。以下是他的评论:

右。所以它实际上并不在磁盘上。您已经下载了mysqlcppconn c ++连接器,而不是mysql C连接器。

所以在我的方式我可以使用mysql_connection.h或下载正确的库。 非常感谢,理查德