当前位置: 首页 > article >正文

关于C/C++Windows下连接MYSQL操作

1.标准目录

2.cmakeList.txt

cmake_minimum_required(VERSION 3.16)

project(MySql LANGUAGES CXX)

set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

# 设置运行时库路径
set(CMAKE_INSTALL_RPATH "C:/Program Files/MySQL/MySQL Server 8.0/lib")
include_directories("C:/Program Files/MySQL/MySQL Server 8.0/include")
# target_link_libraries(MySql "C:/Program Files/MySQL/MySQL Server 8.0/lib/libmysql.lib")
# 查找指定目录下的所有库文件(这里假设库文件以.lib结尾)
file(GLOB LIB_FILES "C:/Program Files/MySQL/MySQL Server 8.0/lib/*.lib")
# 遍历并链接找到的库文件
foreach(LIB_FILE ${LIB_FILES})
    target_link_libraries(MySql ${LIB_FILE})
endforeach()

add_executable(MySql main.cpp)

include(GNUInstallDirs)
install(TARGETS MySql
    LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
    RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
)

拷贝C:/Program Files/MySQL/MySQL Server 8.0/lib下文件到可执行程序下

3.测试代码

#include <iostream>

#include"mysql.h"

using namespace std;

int main()
{
    cout << "mysq version:" <<mysql_get_client_info()<< endl;

    // 初始化MySQL连接对象
    MYSQL *conn = mysql_init(NULL);
    if (conn == NULL) {
        std::cerr << "mysql_init() failed" << std::endl;
        return 1;
    }
    // 连接到MySQL数据库
    if (mysql_real_connect(conn, "localhost", "root", "123456", "db01", 0, NULL, 0)== NULL) {
        std::cerr << "mysql_real_connect() failed: " << mysql_error(conn) << std::endl;
        mysql_close(conn);
        return 1;
    }
    // 执行查询语句
    if (mysql_query(conn, "SELECT * FROM tb_user")) {
        std::cerr << "mysql_query() failed: " << mysql_error(conn) << std::endl;
        mysql_close(conn);
        return 1;
    }
    // 获取结果集
    MYSQL_RES *result = mysql_store_result(conn);
    if (result == NULL) {
        std::cerr << "mysql_store_result() failed: " << mysql_error(conn) << std::endl;
        mysql_close(conn);
        return 1;
    }
    // 获取结果集中的行数和列数
    int num_fields = mysql_num_fields(result);
    MYSQL_ROW row;
    while ((row = mysql_fetch_row(result))) {\

        for (int i = 0; i < num_fields; i++) {
            std::cout << row[i] << " ";
        }
        std::cout << std::endl;
    }
    // 释放结果集内存
    mysql_free_result(result);
    // 关闭数据库连接
    mysql_close(conn);
    return 0;
}

4.结果


http://www.kler.cn/a/407216.html

相关文章:

  • 深度学习每周学习总结J6(ResNeXt-50 算法实战与解析 - 猴痘识别)
  • Vue实训---0-完成Vue开发环境的搭建
  • AR智能眼镜|AR眼镜定制开发|工业AR眼镜方案
  • 客户流失分析综述
  • 【Linux】-学习笔记04
  • 文件管理 II(文件的物理结构、存储空间管理)
  • 【深度学习之二】正则化函数(weight decay, dropout, label smoothing, and etc)详解,以及不同的函数适用的场景
  • 闫妮—《小巷人家》中的宝藏演员
  • Linux各种并发服务器优缺点
  • Vue3移动端-点餐项目
  • AOC显示器915Sw按键失灵维修记
  • Java爬虫:获取商品详情的实践之旅
  • 在Ubuntu上使用Python和OpenCV库来处理和显示图片
  • 【学习】使用pam_cracklib校验密码复杂度
  • Java程序设计——(一)Java开发入门(1)Java程序的基本格式
  • Python和Julia(多语言)急性呼吸窘迫综合征
  • 32、js弹框操作
  • Gate学习(5) 指令学习2
  • 精简脂肪:为物联网引入QUIC轻应用
  • 微信小程序条件渲染与列表渲染的全面教程
  • Linux内核(二)——内核编译与安装
  • 【LGR-208-Div.3】洛谷基础赛 #18 P11308 茫茫的不归路
  • 2024 APMCM亚太数学建模C题 - 宠物行业及相关产业的发展分析和策略(详细解题思路)
  • 【jvm】new对象的过程
  • 活着就好20241124
  • Ansys Zemax Optical Studio 中的近视眼及矫正