【Qt】加载MySQL数据库驱动失败的解决方法
文章目录
- 问题概述
- 编译MySQL数据库驱动
- 安装MySQL Community Server
- 编译qsqlmysql库
问题概述
已经安装了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驱动加载失败问题解决方法