VS2022+QT5.15.2+MySQL8.4大集合

网上的教程都建议用Qt5,不要用6,不死心的尝试了整整一天失败了,乖乖用回5,qt5需要编译一下生成mysql的动态和静态库

  1. mysql8.4安装

下载社区开发版,注意要64位

https://dev.mysql.com/downloads/mysql/

配置一下数据库为了后面测试用

这里配置端口及root密码,保证和最后一步的测试代码一致就行

在mysql命令行中新建一个测试数据库

  1. qt5.15.2安装

清华镜像,在线安装:Index of /qt/official_releases/online_installers/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

注意现在5的老版本需要先选Archive再选Filter

需要选如下三个,Sources是用来编译Mysql库的

  1. qt编译Mysql库

找到Qt安装目录下 \5.15.2\Src\qtbase\src\plugins\sqldrivers\mysql

双击打开mysql.pro文件,会自动启动qtcreator,进行如下修改,引入Mysql8.4的头文件 & lib

再修改qsqldriverbase.pri文件

如果你电脑里有多个qt版本,要选择正确的构建版本,针对vs2022的是这个:

此时目录\5.15.2\msvc2019_64\qtbase\src\plugins\sqldrivers\plugins\sqldrivers下会生成

qsqlmysql.dll、qsqlmysqld.dll两个动态库,qsqlmysql.lib、qsqlmysqld.lib两个静态库

将两个动态库拷贝到\5.15.2\Src\qtbase\src\plugins\sqldrivers、

以及\5.15.2\msvc2019_64\plugins\sqldrivers下

注意如果后面遇到【QSqlDatabase: QMYSQL driver not loaded】问题,很可能是忘了拷贝到后者目录

至此,qt编译mysql结束

  1. vs2022引入qt扩展

这一步一般不会出现什么问题

vs2022我选了这几项

3.1 安装vs拓展工具(关闭vs2022)

去官网下载拓展管理器vsaddin,双击安装。安装的时候要关闭vs2022。

Index of /official_releases/vsaddin/2.9.1

3.2 配置qt版本

vs需要手工指定qt版本

上方选项卡:扩展 - Qt VS Tools - Qt Versions

选择5.15.2\msvc2019_64\bin\qmake.exe

后面就可以新建qt项目了

  1. 测试qt+mysql是否成功

新建一个qt项目后,在include & lib中加入qt & Mysql的头文件及lib路径

在linker - input中指定具体静态库

main函数中编写测试代码:

cpp 复制代码
#include <QCoreApplication>
#include <QSqlDatabase>
#include <QDebug>

int main(int argc, char* argv[])
{
    QCoreApplication a(argc, argv);

    // 连接mysql的test数据库测试代码
    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
    db.setHostName("127.0.0.1");  //连接本地主机
    db.setPort(3306);
    db.setDatabaseName("test2"); //上面新建的数据库名称
    db.setUserName("root");
    db.setPassword("123456"); // 你的mysql数据库设置的密码
    bool ok = db.open();
    if (ok) {
        qDebug() << "infor link success";
    }
    else {
        qDebug() << "infor link failed";
        qDebug() << "error open database because"; //<<db.lastError().text();
    }

    return a.exec();
}

理论上弹出success的对话框就work了

相关推荐
2501_933329551 小时前
企业级舆情监测系统技术解析:Infoseek数字公关AI中台架构与实践
开发语言·人工智能·自然语言处理·架构
Wave8451 小时前
C++继承详解
开发语言·c++·算法
Tairitsu_H1 小时前
C++类基础概念:定义、实例化和this指针
开发语言·c++
.柒宇.1 小时前
Java八股之反射
java·开发语言
环流_1 小时前
多线程1(面试题--常见的线程创建方式)
java·开发语言·面试
Han_han9192 小时前
常用API:
java·开发语言
minji...2 小时前
Linux 线程同步与互斥(四) POSIX信号量,基于环形队列的生产者消费者模型
linux·运维·服务器·c语言·开发语言·c++
Highcharts.js2 小时前
在 React 中使用 useState 和 @highcharts/react 构建动态图表
开发语言·前端·javascript·react.js·信息可视化·前端框架·highcharts
likerhood3 小时前
java中的return this、链式编程和Builder模式
java·开发语言
原来是猿3 小时前
Linux线程同步与互斥(三):POSIX信号量与环形队列生产者消费者模型
linux·运维·服务器·开发语言