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了

相关推荐
小_太_阳4 分钟前
Scala_【1】概述
开发语言·后端·scala·intellij-idea
向宇it4 分钟前
【从零开始入门unity游戏开发之——unity篇02】unity6基础入门——软件下载安装、Unity Hub配置、安装unity编辑器、许可证管理
开发语言·unity·c#·编辑器·游戏引擎
古希腊掌管学习的神41 分钟前
[LeetCode-Python版]相向双指针——611. 有效三角形的个数
开发语言·python·leetcode
赵钰老师42 分钟前
【R语言遥感技术】“R+遥感”的水环境综合评价方法
开发语言·数据分析·r语言
就爱学编程1 小时前
重生之我在异世界学编程之C语言小项目:通讯录
c语言·开发语言·数据结构·算法
Oneforlove_twoforjob1 小时前
【Java基础面试题025】什么是Java的Integer缓存池?
java·开发语言·缓存
emoji1111111 小时前
前端对页面数据进行缓存
开发语言·前端·javascript
每天都要学信号1 小时前
Python(第一天)
开发语言·python
TENET信条1 小时前
day53 第十一章:图论part04
开发语言·c#·图论
生信圆桌2 小时前
【生信圆桌x教程系列】如何安装 seurat V5版本R包,最详细安装手册
开发语言·r语言