打包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

解决方法:

  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的编译器有关。

转载于:https://www.cnblogs.com/FlameBlog/p/11299349.html

你可能感兴趣的:(打包Qt程序后调用MySQL时出现 QMYSQL driver not loaded)