QT5安装mysql驱动连接服务器数据库MYSQL
创始人
2024-09-25 15:22:29
0

qt安装mysql驱动

简介

一、下载qt源码

二、下载mysql起始文件

三、编译mysql得到驱动文件

四、copy动态库文件

五、安装完成进行测试

简介

最近的工作需要使用mysql连接服务器数据库,但我发现我的qt5.15.2没有mysql的驱动

image

对于qt是不是有mysql驱动,可以看下这个路径下面是不是有qsqlmysql的dll

image

此时我们需要有mysql的起始文件、qtsource源码

一、下载qt源码

先去把source下载,qc打开路径

image

用这个qt maintenance tool

image

打开后登录一下,选择添加或移除组件

image

把source点上,然后更新,就会下载qt源码了

image

二、下载mysql起始文件

网址:https://github.com/thecodemonkey86/qt_mysql_driver?tab=readme-ov-file

用这个博主的,就不用安装mysql了

image

这三个下完,解压,是个组合的压缩包 点1就把123都解压到一个文件夹了

可以看到有个include和lib

image

三、编译mysql得到驱动文件

这会源码应该下完了,到达这个qt安装路径:…\qt6\5.15.2\Src\qtbase\src\plugins\sqldrivers\mysql,打开mysql.pro

image

image

更改pro文件,如下 路径就按照你解压的文件,最好不要带中文,把QMAKE_USE注释掉

TARGET = qsqlmysql  HEADERS += $$PWD/qsql_mysql_p.h SOURCES += $$PWD/qsql_mysql.cpp $$PWD/main.cpp  #QMAKE_USE += mysql  OTHER_FILES += mysql.json  PLUGIN_CLASS_NAME = QMYSQLDriverPlugin # !!mysql的lib路径 LIBS += -L $$quote(D:\008_LY_HOST_\libmysql_8.0.29\lib) -llibmysql # !!mysql的include路径 INCLUDEPATH += $$quote(D:\008_LY_HOST_\libmysql_8.0.29\include) # !!mysql的include路径 DEPENDPATH += $$quote(D:\008_LY_HOST_\libmysql_8.0.29\include)   include(../qsqldriverbase.pri) 

写完运行一下,报什么错可以不管,只要进度条走到头就好了

image

然后在这个路径下:…\qt6\5.15.2\mingw81_64\qtbase\src\plugins\sqldrivers\plugins\sqldrivers,就会出现这三个文件,红色字体跟你的编译器有关

image

把这两个copy到…\qt6\5.15.2\mingw81_64\plugins\sqldrivers

image

如此

image

驱动就此完成!

注意每一个编译器对于一个驱动,并不是说我64位的安装了,32就能用,32位的也要照此操作一次才行。

每一个驱动对应到qt编译器的版本

四、copy动态库文件

把刚刚解压的文件lib下的libmysql.dll动态库文件copy到…\qt6\5.15.2\mingw81_64\bin

image

image

五、安装完成进行测试

新建一个qt工程,pro文件在gui后面加sql

image

mian函数抄这个

#include  #include  #include  #include  #include   int main(int argc, char *argv[]) {     QCoreApplication a(argc, argv);      // 创建数据库连接     QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");     db.setHostName("公网ip");     db.setPort(3306);     db.setDatabaseName("数据库名字"); // 替换为你的数据库名     db.setUserName("数据库用户名");     db.setPassword("密码");      // 尝试打开数据库     if (db.open()) {         qDebug() << "Connection successful!";     } else {         qDebug() << "Connection failed: " << db.lastError().text();     }      return a.exec(); }  

运行一下

image

连接成功不报错,安装成功!

相关内容

热门资讯

五分钟系统!(pokernow... 五分钟系统!(pokernow德州)辅助挂,(轰趴十三水)一贯真的有挂,详细教程(有挂学习)确实是有...
2分钟德州!(pokenow)... 2分钟德州!(pokenow)发牌规律性总结,(欢乐棋牌)就是真的有挂,wepoke教程(有挂透视)...
4分钟模拟器!(鱼扑克app俱... 4分钟模拟器!(鱼扑克app俱乐部)最新辅助,(扑克王)一直真的有挂,AI教程(有挂模拟器)确实是有...
3分钟苹果版本!(epoker... 3分钟苹果版本!(epoker)真的有挂,(gg扑克)一贯真的有挂,力荐教程(有挂绝活儿)1、打开德...
一分钟ai辅助!(cloudp... 一分钟ai辅助!(cloudpoker云扑克)智能ai,(智星德州菠萝)原来真的有挂,规律教程(有挂...
5分钟自建房!(impoker... 5分钟自建房!(impoker德州)ai辅助,(轰趴十三水)果然真的有挂,我来教教你(有挂妙计)1、...
2分钟ai辅助!(红龙软件德州... 2分钟ai辅助!(红龙软件德州扑克)辅助工具苹果,(poker master安卓版)好像真的有挂,必...
5分钟机制!(fishpoke... 5分钟机制!(fishpoker俱乐部)有透视辅助吗,(poker world)总是真的有挂,切实教...
一分钟开挂!(来玩app德州扑... 一分钟开挂!(来玩app德州扑克)机制,(红龙软件德州扑克)原来真的有挂,揭秘教程(有挂资料)确实是...
2分钟机器人!(EV扑克)智能... 2分钟机器人!(EV扑克)智能ai辅助,(cloudpoker云扑克)好像真的有挂,微扑克教程(有挂...