zoukankan      html  css  js  c++  java
  • 打包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 将程序打包,该程序在QtQt5.12.25.12.2msvc2017_64in 下,一般可以解析出其他部分的依赖库文件并拷贝到当前路径。
    2. 将 libmysql.dll 放在程序运行路径下,libmysql.dl在安装MySQL后,从 C:Program FilesMySQLMySQL Server 8.0lib中拷贝 。
    3. 在程序的运行路径下创建plugins文件夹,将windeployqt.exe生成的sqldrivers文件夹移到plugins文件夹下。
    4. 因为libmysql.dll是会调用SSL的所以,如果你的系统没有的话,则需要自己将相应的库文件拷贝到应用的运行路径下,以保证更换电脑之后可运行,具体需要拷贝的库文件包括:libeay32.dll,ssleay32.dll。你也可以通过 depends.exe 自己观察依赖库文件都有哪些。

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

    任世事无常,勿忘初心
  • 相关阅读:
    WireShark抓包软件的使用
    UNIX环境高级编程--#include "apue.h"
    用OpenCV实现Otsu算法
    Qt使用快捷键
    Ubuntu14.04如何备份和恢复系统
    Linux命令--链接文件的那些事
    Python读写csv文件
    Python正则表达式指南
    Linux下使用rsync最快速删除海量文件的方法
    性能监控工具——Cacti安装文档
  • 原文地址:https://www.cnblogs.com/FlameBlog/p/14715345.html
Copyright © 2011-2022 走看看