当前位置: 首页 > article >正文

【Qt】加载MySQL数据库驱动失败的解决方法

文章目录

  • 问题概述
  • 编译MySQL数据库驱动
      • 安装MySQL Community Server
      • 编译qsqlmysql库

问题概述

已经安装了MySQL Server 8.0,但是在Qt程序中使用MySQL数据库驱动,依然提示找不到。看了网上一些教程,大体上都是说将MySQL的lib文件夹下的libmysql.dll和libmysql.lib文件拷贝到Qt的安装目录的bin文件夹下,但仅仅操作这一步的话,还是没有办法解决我找不到数据库驱动的问题。如果你也像我一样,那么我们可能需要自己编译数据库驱动。

编译MySQL数据库驱动

安装MySQL Community Server

https://dev.mysql.com/downloads/mysql/
在这里插入图片描述
点击Archives,选择版本和平台并下载
在这里插入图片描述
解压并记住这个路径(编译时需要用),例如,我解压在Qt安装目录下
在这里插入图片描述

编译qsqlmysql库

打开Qt源码目录下的mysql.pro,以安装在C盘的Qt 5.15.2为例,路径为:
C:\Qt\5.15.2\Src\qtbase\src\plugins\sqldrivers\mysql
在这里插入图片描述
pro文件有几个需要设置的地方
1、添加include目录、依赖库目录、生成文件目录
在这里插入图片描述

注意:DESTDIR可以是任意目录,但是编辑完成后,记得执行qmake,否则不会生成一个新的目录,这样即使编译成功也找不到目标文件。

2、注释掉QMAKE_USE += mysql
否则可能会报错:Library ‘mysql’ is not defined.
请添加图片描述
3、打开qsqldriverbase.pri,将 include($$shadowed($$PWD)/qtsqldrivers-config.pri) 改成 include(./configure.pri)
在这里插入图片描述
否则可能会报错:Cannot read xxx/qtbase/src/plugins/sqldrivers/qtsqldrivers-config.pri
请添加图片描述
点击重新构建,lib目录下会生成一些库文件,其中qsqlmysql.dll和qsqlmysqld.dll是我们需要的
在这里插入图片描述
把这两个文件复制到Qt插件目录下的sqldrivers中
在这里插入图片描述
将MySQL安装目录下的lib文件夹下的libmysql.dll,复制到Qt编译器的bin目录下
在这里插入图片描述
在这里插入图片描述
此时,再启动Qt程序,打印当前数据库的驱动,就有mysql数据库驱动了
在这里插入图片描述
【参考】
Qt Windows环境下如何添加MYSQL数据库驱动
Qt中使用MySQL数据库详解,好用的模块类封装
Qt连接MySql驱动加载失败问题解决方法


http://www.kler.cn/a/443039.html

相关文章:

  • 天童教育:用电影教学增添学习趣味
  • iOS - 弱引用表(Weak Reference Table)
  • 解决idea中无法拖动tab标签页的问题
  • 百度Android面试题及参考答案 (下)
  • 阿里云直播互动Web
  • 代码随想录 哈希 test 8
  • linux 安装redis
  • 【每日一题 基础题】[蓝桥杯 2020 省 AB3] 乘法表
  • 2025年入职/转行网络安全,该如何规划?网络安全职业规划
  • 【自动驾驶】单目摄像头实现自动驾驶3D目标检测
  • 《Django 5 By Example》阅读笔记:p551-p560
  • Ubuntu如何下载nvidia驱动和Cuda Toolkit
  • iOS swift开发系列--如何给swiftui内容视图添加背景图片显示
  • 王佩丰24节Excel学习笔记——第十三讲:邮件合并
  • 力扣--LCR 183.望远镜中的最高海拔
  • Linux文件属性 --- 硬链接、所有者、所属组
  • 15.初识接口1 C#
  • thinkphp:try-catch捕获异常
  • flutter --no-color pub get 超时解决方法
  • 51单片机-内部扩展RAM的应用
  • nlp初学者怎么入门?需要学习哪些?
  • MySQL技术:深入理解索引与优化
  • 提升PHP技能:18个实用高级特性
  • Linux docker离线部署
  • 基于Armitage的MSF自动化集成攻击实践
  • Android显示系统(12)- 向SurfaceFlinger申请Buffer