QT5安装mysql驱动连接服务器数据库MYSQL

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 <QCoreApplication>
#include <QtSql/QSqlDatabase>
#include <QtSql/QSqlError>
#include <QtSql/QSqlQuery>
#include <QDebug>

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值