IDE选用CLion
这是我数据库里的数据(db1数据库里的user表)
首先将本地MySQL的lb文件夹里的libmysql.dll和libmysql.lib这两个文件复制到cmake-build-debug文件夹下,这两个文件在我的mysql路径如下:D:\mysql\mysql-8.0.30-winx64\lib\libmysql.dll 和 D:\mysql\mysql-8.0.30-winx64\lib\libmysql.lib
添加后cmake-build-dubug目录如下:
在CLion项目里新建4个文件:
① CMakeLists.txt
② myDb.h
③ myDb.cpp
④ main.cpp
四个文件里面的内容如下(mysql路径、数据库密码和项目名称根据自己的实际情况更改):
CMakeLists.txt
cmake_minimum_required(VERSION 3.24)
project(cppProjects)
set(CMAKE_CXX_STANDARD 14)
include_directories(D:\\mysql\\mysql-8.0.30-winx64\\include)
link_directories(D:\\mysql\\mysql-8.0.30-winx64\\lib)
link_directories(libmysql)
add_executable(cppProjects
main.cpp test.cpp test.h myDb.h myDb.cpp)
target_link_libraries(cppProjects libmysql)
myDb.h
//
// Created by asus on 2023/3/24.
//
#ifndef CPPPROJECTS_MYDB_H
#define CPPPROJECTS_MYDB_H
#endif //CPPPROJECTS_MYDB_H
/**
* file MyDb.h
*
* Created by shiyibo on 2018/12/21.
*/
#ifndef DB_MYDB_H
#define DB_MYDB_H
#include <string>
#include "D:/mysql/mysql-8.0.30-winx64/include/mysql.h"
using namespace std;
class MyDb {
public:
MyDb();
~MyDb();
/**
* 连接mysql
*
* @param host
* @param user
* @param pwd
* @param db_name
* @param port
* @return
*/
bool initDB(string host, string user,string pwd,string db_name, int port);
/**
* 执行sql语句
*
* @param sql
* @return
*/
bool exeSQL(string sql);
private:
/**
* 连接mysql句柄指针
*/
MYSQL *mysql;
/**
* 指向查询结果的指针
*/
MYSQL_RES *result;
/**
* 按行返回的查询信息
*/
MYSQL_ROW row;
};
#endif //DB_MYDB_H
myDb.cpp
//
// Created by asus on 2023/3/24.
//
/**
* file MyDb.cpp
* Created by shiyibo on 2018/12/21.
*/
#include <iostream>
#include <string>
#include "MyDb.h"
using namespace std;
/**
* 初始化数据库连接变量
*/
MyDb::MyDb()
{
mysql = mysql_init(NULL);
if(!mysql) {
cout<<"Error:"<<mysql_error(mysql);
exit(1);
}
}
/**
* 释放资源
*/
MyDb::~MyDb()
{
if(mysql) {
mysql_close(mysql);
}
}
/**
*
* @param host
* @param user
* @param passwd
* @param db_name
* @oaram port
* @return
*/
bool MyDb::initDB(std::string host, std::string user, std::string passwd, std::string db_name, int port = 3306)
{
mysql = mysql_real_connect(mysql, host.c_str(), user.c_str(), passwd.c_str(), db_name.c_str(), port, NULL, 0);
if(!mysql) {
cout << "Error: " << mysql_error(mysql);
exit(1);
}
return true;
}
/**
* 执行sql 语句
* @param sql
* @return
*/
bool MyDb::exeSQL(std::string sql)
{
//mysql_query()执行成功返回0,执行失败返回非0值。
if (mysql_query(mysql,sql.c_str())) {
cout<<"Query Error: "<<mysql_error(mysql);
return false;
}
result = mysql_store_result(mysql);
if (result) {
//获取结果集中总共的字段数,即列数
int num_fields = mysql_num_fields(result);
unsigned long long num_rows = mysql_num_rows(result);
for(unsigned long long i = 0; i < num_rows; i++) {
row = mysql_fetch_row(result);
if(!row) {
break;
}
for(int j=0;j<num_fields;j++) {
cout<<row[j]<<"\t\t";
}
cout<<endl;
}
} else {
//代表执行的是update,insert,delete类的非查询语句
if (mysql_field_count(mysql) == 0) {
// 返回update,insert,delete影响的行数
unsigned long long num_rows = mysql_affected_rows(mysql);
return num_rows;
} else {
cout << "Get result error: " << mysql_error(mysql);
return false;
}
}
return true;
}
main.cpp
//
// Created by asus on 2023/3/24.
//
#include <iostream>
#include "MyDb.h"
int main() {
// std::cout << "Hello, World!" << std::endl;
system("chcp 65001");
MyDb db;
string host = "127.0.0.1";
string user = "root";
string passwd = "yourpassword"; //这里输入你自己的密码
string dbName = "db1";
int port = 3306;
cout<<"start\n";
//连接数据库
bool conn = db.initDB(host, user, passwd, dbName, port);
if (!conn) {
cout<<"connect fails\n";
}
cout<<"ok" <<endl;
string sql;
//将用户信息添加到数据库
// sql = "INSERT user values(12 'fengxin', 39);";
// db.exeSQL(sql);
//将所有用户信息读出,并输出。
sql = "SELECT * from user";
db.exeSQL(sql);
return 0;
}
完整项目目录如下:
运行项目,输出select查询内容