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

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

相关内容

热门资讯

透视辅助(德州ai)其实真的有... 透视辅助(德州ai)其实真的有挂(透视)微扑克钻石能提高胜率吗(详细透视辅助教程);科技详细教程小薇...
透视辅助(红龙扑克)其实真的有... 透视辅助(红龙扑克)其实真的有挂(透视)德扑软件高端(详细辅助透视教程)是一款可以让一直输的玩家,快...
透视辅助(德扑ai)其实真的有... 透视辅助(德扑ai)其实真的有挂(辅助挂)德州之星app辅助器怎么用(详细透明挂教程);科技安装教程...
透明辅助(红龙扑克)其实真的有... 您好,wpk俱乐部有ai吗这款游戏可以开挂的,确实是有挂的,需要了解加微【487309276】很多玩...
透明辅助(WePoKe)原来真... 透明辅助(WePoKe)原来真的有挂(透视)wpk辅助插件(详细透视辅助教程)1、wpk辅助插件透视...
透明辅助(WPK)原来真的有挂... 透明辅助(WPK)原来真的有挂(透视)wepooke系统规律(详细透视教程)1、进入到wepooke...
透明辅助(德州ai)原来真的有... 1、透明辅助(德州ai)原来真的有挂(辅助挂)wpk使用ai辅助会封号吗(详细透明挂教程)(UU p...
透明辅助(AApoker)其实... 透明辅助(AApoker)其实真的有挂(辅助挂)德州poker有外挂吗(详细透视教程)1、完成德州p...
透明辅助(WePoKe)原来真... 透明辅助(WePoKe)原来真的有挂(辅助挂)wopoker苹果怎么下载(详细辅助挂教程)1、操作简...
透明辅助(德州ai)其实真的有... 透明辅助(德州ai)其实真的有挂(辅助挂)云扑克内置辅助器(详细透视教程)1、让任何用户在无需AI插...