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

2024-06-01 1080阅读

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

1. mysql8.4安装

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

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

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

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

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

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

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

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

2. qt5.15.2安装

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

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

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

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

3. qt编译Mysql库

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

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

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

再修改qsqldriverbase.pri文件

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

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

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

此时目录\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结束

3. vs2022引入qt扩展

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

vs2022我选了这几项

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

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

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

后面就可以新建qt项目了

4. 测试qt+mysql是否成功

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

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

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

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

main函数中编写测试代码:

#include 
#include 
#include 
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() 
VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]