打包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[...]

解决方法:

  1. 使用 windeployqt.exe 将程序打包,该程序在\Qt\Qt5.12.2\5.12.2\msvc2017_64\bin\ 下,一般可以解析出其他部分的依赖库文件并拷贝到当前路径。
  2. 将 libmysql.dll 放在程序运行路径下,libmysql.dl在安装MySQL后,从 C:\Program Files\MySQL\MySQL Server 8.0\lib中拷贝 。
  3. 在程序的运行路径下创建plugins文件夹,将windeployqt.exe生成的sqldrivers文件夹移到plugins文件夹下。
  4. 因为libmysql.dll是会调用SSL的所以,如果你的系统没有的话,则需要自己将相应的库文件拷贝到应用的运行路径下,以保证更换电脑之后可运行,具体需要拷贝的库文件包括:libeay32.dll,ssleay32.dll。你也可以通过 depends.exe 自己观察依赖库文件都有哪些。

值得注意的是在libmysql.dll只要在已知路径中,可被程序访问即可,而plugins下的驱动只能在指定路径下,不知为何,可能跟Qt的编译器有关。

posted @ 2021-04-28 18:37  FlameAlpha  阅读(622)  评论(0编辑  收藏  举报