我是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(&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中使用的路径下载和提取的库
请帮助我,不仅仅是想写下你的想法,我已经用谷歌搜索了半天,并阅读了很多东西。只是写在这里就像你不正确,或者你忘了这段代码或行。
答案 0 :(得分:0)
右。所以它实际上并不在磁盘上。您已经下载了mysqlcppconn c ++连接器,而不是mysql C连接器。
所以在我的方式我可以使用mysql_connection.h或下载正确的库。 非常感谢,理查德