最近操作系统换成windows10,在编写QT访问mysql的使用出现了一些问题,现在将问题以及解决方案总结记录一下
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位的。
手动编译qt中的mysql驱动文件
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"
|
最后可以把将C:/Program Files (x86)/MySQL/MySQL Server 5.7/lib/libmysql.dll 复制到 C:/Windows目录下。为了保险最好重新启动一下windows操作系统。
把mysql中的dll文件复制到项目编译好的目录的debug或release中
我这里安装的是MySQL5.7.28在安装的时候需要选择安装C++的dll库
安装完成以后,将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目录。
这种方式在部分的电脑可以成功,但是也有些系统不成功。