windows下C++连接本地MySQL数据库

IDE选用CLion

这是我数据库里的数据(db1数据库里的user表)
请添加图片描述
首先将本地MySQL的lb文件夹里的libmysql.dlllibmysql.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查询内容

请添加图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值