【Qt】加载MySQL数据库驱动失败的解决方法

问题概述

已经安装了MySQL Server 8.0,但是在Qt程序中使用MySQL数据库驱动,依然提示找不到。看了网上一些教程,大体上都是说将MySQL的lib文件夹下的libmysql.dll和libmysql.lib文件拷贝到Qt的安装目录的bin文件夹下,但仅仅操作这一步的话,还是没有办法解决我找不到数据库驱动的问题。如果你也像我一样,那么我们可能需要自己编译数据库驱动。

编译MySQL数据库驱动

安装MySQL Community Server

https://dev.mysql.com/downloads/mysql/
在这里插入图片描述
点击Archives,选择版本和平台并下载
在这里插入图片描述
解压并记住这个路径(编译时需要用),例如,我解压在Qt安装目录下
在这里插入图片描述

编译qsqlmysql库

打开Qt源码目录下的mysql.pro,以安装在C盘的Qt 5.15.2为例,路径为:
C:\Qt\5.15.2\Src\qtbase\src\plugins\sqldrivers\mysql
在这里插入图片描述
pro文件有几个需要设置的地方
1、添加include目录、依赖库目录、生成文件目录
在这里插入图片描述

注意:DESTDIR可以是任意目录,但是编辑完成后,记得执行qmake,否则不会生成一个新的目录,这样即使编译成功也找不到目标文件。

2、注释掉QMAKE_USE += mysql
否则可能会报错:Library ‘mysql’ is not defined.
请添加图片描述
3、打开qsqldriverbase.pri,将 include($$shadowed($$PWD)/qtsqldrivers-config.pri) 改成 include(./configure.pri)
在这里插入图片描述
否则可能会报错:Cannot read xxx/qtbase/src/plugins/sqldrivers/qtsqldrivers-config.pri
请添加图片描述
点击重新构建,lib目录下会生成一些库文件,其中qsqlmysql.dll和qsqlmysqld.dll是我们需要的
在这里插入图片描述
把这两个文件复制到Qt插件目录下的sqldrivers中
在这里插入图片描述
将MySQL安装目录下的lib文件夹下的libmysql.dll,复制到Qt编译器的bin目录下
在这里插入图片描述
在这里插入图片描述
此时,再启动Qt程序,打印当前数据库的驱动,就有mysql数据库驱动了
在这里插入图片描述
【参考】
Qt Windows环境下如何添加MYSQL数据库驱动
Qt中使用MySQL数据库详解,好用的模块类封装
Qt连接MySql驱动加载失败问题解决方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值