windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

时间:2024-04-10 17:11:48

最近操作系统换成windows10,在编写QT访问mysql的使用出现了一些问题,现在将问题以及解决方案总结记录一下
 

 

windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

Windows下使用qt连接mysql数据库时,总是出现QSqlDatabase: QMYSQL driver not loaded的问题。

首先,比较麻烦的解决方案是重新编译QT中mysql的驱动文件qsqlmysql.dll,还有一种简单方法是把libmysql.dll复制到指定的目录。

第二种解决方案是拷贝MySQL的lib下的libmysql.dll和libmysql.lib文件复制到C:\Qt\Qt5.14.0\5.14.0\mingw73_32\bin目录下或者复制到项目的编译的debug和release目录。

注意:无论哪种方式都需要确保MySQL和Qt的位数一样,都是32位的或都是64位的。

 

解决方案1:

手动编译qt中的mysql驱动文件

  • 1、添加系统的环境变量

windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

 

  • 2、修改C:\Qt\Qt5.14.0\5.14.0\Src\qtbase\src\plugins\sqldrivers\qtsqldrivers-config_p.h文件把mysql后的数字改为1,改为1标识使用,改为-1标识忽略

windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

 

  • 3、打开cmd命令行,进入sqldrivers目录执行qmake编译,注意指定mysql的include和lib

Cd C:\Qt\Qt5.14.0\5.14.0\Src\qtbase\src\plugins\sqldrivers

qmake -- MYSQL_INCDIR="C:/Program Files (x86)/MySQL/MySQL Server 5.7/include" MYSQL_LIBDIR="C:/Program Files (x86)/MySQL/MySQL Server 5.7/lib"

 

windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

 

  • 4、执行mingw32-make命令进行编译

windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

  • 5、执行mingw32-make install命令进行安装

windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

最后可以把将C:/Program Files (x86)/MySQL/MySQL Server 5.7/lib/libmysql.dll  复制到 C:/Windows目录下。为了保险最好重新启动一下windows操作系统

 

 

 

解决方案2:

把mysql中的dll文件复制到项目编译好的目录的debug或release中

我这里安装的是MySQL5.7.28在安装的时候需要选择安装C++的dll库

windows10下使用Qt5.14.0连接MySQL5.7.28错误:QMYSQL driver not loaded的问题完美解决方案

安装完成以后,将C:/Program Files (x86)/MySQL/MySQL Server 5.7/lib下的下的libmysql.dll和libmysql.lib文件复制到C:\Qt\Qt5.14.0\5.14.0\mingw73_32\bin目录或者复制到编译后的debug或release目录。

这种方式在部分的电脑可以成功,但是也有些系统不成功。