打包Qt程序后调用MySQL时出现 QMYSQL driver not loaded(更换电脑仍可用)
错误日志:
QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers:
QSqlDatabase: an instance of QCoreApplication is required for loading driver plugins
本文程序的依赖关系如下
graph LR
A[Qt程序] -- 依赖 --> B[libmysql.dll]
A -- 依赖 --> F[其他库文件]
B-- 依赖 --> C[libeay32.dll ssleay32.dll等]
C-- 依赖 --> D[...]
解决方法:
- 使用 windeployqt.exe 将程序打包,该程序在
\Qt\Qt5.12.2\5.12.2\msvc2017_64\bin\
下,一般可以解析出其他
部分的依赖库文件并拷贝到当前路径。 - 将 libmysql.dll 放在程序运行路径下,libmysql.dl在安装MySQL后,从
C:\Program Files\MySQL\MySQL Server 8.0\lib
中拷贝 。 - 在程序的运行路径下创建plugins文件夹,将windeployqt.exe生成的sqldrivers文件夹移到plugins文件夹下。
- 因为libmysql.dll是会调用SSL的所以,如果你的系统没有的话,则需要自己将相应的库文件拷贝到应用的运行路径下,以保证更换电脑之后可运行,具体需要拷贝的库文件包括:libeay32.dll,ssleay32.dll。你也可以通过 depends.exe 自己观察依赖库文件都有哪些。
值得注意的是在libmysql.dll只要在已知路径中,可被程序访问即可,而plugins下的驱动只能在指定路径下,不知为何,可能跟Qt的编译器有关。
任世事无常,勿忘初心