背景:

  本科毕业设计涉及图形界面与数据库查询。选择使用Qt实现图形界面编程,使用MySQL构建数据库。之前安装了Qt 5.2,后来又安装了MySQL Server 5.6 (FULL完全安装)。接着就遇到了" QMYSQL driver not loaded "的问题。

参考网站:

  <http://mobile.51cto.com/symbian-273258.htm>

  <http://mobile.51cto.com/symbian-268134.htm>

  <http://1029975378-qq-com.iteye.com/blog/1310910>

  <http://blog.sina.com.cn/s/blog_74a7e56e01017s64.html>

  <http://blog.csdn.net/styyzxjq2009/article/details/8131917>

  <http://qt-project.org/doc/qt-5/sql-driver.html>

  我之所以参考这么多的网站,是因为他们的整体思路都一样,但是都解决不了我的问题,但是都能对我解决问题有所启发。

解决问题的过程:

一 )准备阶段:

  1. 安装Qt(我的是5.2版本,主目录C:\Qt\Qt5.2.1\5.2.1\mingw48_32),主目录中只有一个mingw48_32文件夹。并不是什么“qt\plugins\...”,也没有“.../src/plugins/...”。所以,根据参考,我去Qt官方网站下载了Qt5.2的源码包“qt-everywhere-opensource-src-5.2.1.zip”。解压后放在了“C:\Qt”文件夹下,并重命名为"Sources"。如下图:

  

在"Sources"文件夹中找到了接下来要工作的目录:“C:\Qt\Sources\qtbase\src\plugins\sqldrivers\mysql”。里面有需要的lib文件和pro文件。

  2. 安装MySQL(我的是5.6版本,原先安装在“C:\Program Files”下,但是考虑到参考中提到的“文件夹命名不能有空格”,于是重新安装在“C:\MySQL”中)。我安装的是“FULL”,完整安装,所以,安装目录“C:\MySQL\MySQL Server 5.6\bin”还是避免不了空格。于是,仿照参考中的指示,重新新建文件夹“E:\MySQL”,将“C:\MySQL\MySQL Server 5.6\bin”中的“include”和“lib”文件夹拷贝到里面。可是我的“lib”文件夹里并没有“opt”子文件夹。但是,有"libmysql.dll",那就足够了不是么?

  3. 下载动态库格式转换工具,网址为: http://www.qtcn.org/download/mingw-utils-0.3.tar.gz,解压后把里边bin目录里的remip.exe拷到“C:\Qt\Qt5.2.1\5.2.1\mingw48_32\bin”目录里。同时,为了保险起见,我还特地下载安装了“MinGW”,并且将刚刚的remip.exe文件也复制了一份放在了“C:\MinGW\bin”文件夹中。

二) 开整

  1. 通过“E:\MySQL\lib\libmysql.lib”生成libmysql.a文件

  打开Qt自带的命令行程序(我用的是win8.1,所以在Qt的菜单目录里能找到,不管是什么系统,这个“Qt 5.2.1 for Desktop (MinGW 4.8 32bit)”程序都应该能在Qt Creator的菜单图标周围找得到。)在命令行窗口中切换到工作目录“E:\MySQL\lib”:

  

运行如下两条命令:

reimp -d libmysql.lib     //生成 libmysql.def文件
dlltool -k -d libmysql.def -l libmysql.a //生成 libmysql.a文件

  2. 编译驱动,工作目录为“C:\Qt\Sources\qtbase\src\plugins\sqldrivers\mysql”

  在“Qt 5.2.1 for Desktop (MinGW 4.8 32bit)”命令窗口中切换工作目录。然后依次执行下面2条命令:、

qmake -o Makefile "INCLUDEPATH+=E:\MySQL\include" "LIBS+=E:\MySQL\lib\libmysql.a" mysql.pro    //注意:里面的目录是上一步的工作目录
mingw32-make

  有的人说需要在编译前将以下两行语句加到“C:\Qt\Sources\qtbase\src\plugins\sqldrivers\mysql”文件夹中的"mysql.pro"文件中,我没有加,但是也编译成功了。

INCLUDEPATH += "E:/MySQL/include"
LIBS += "E:/MySQL/lib/libmysql.lib"

  编译之后没有报错、没有大篇幅的error,那就说明编译成功了。(下面这是别人的截图,我的跟这个差不多)

  

三)如果不幸编译失败

  很多时候,成功并不会一蹴而就。就像,你现在编译不成功一样。

  编译不成功有很多原因,如果你发现在编译的结果中出现了神马“Microsoft Visual Studio”之类的问题,那一定是在环境变量中将微软VS的库设置为环境变量了。删掉后重新编译。如果要重新编译,记得将之前编译的结果以及Makefile文件都删掉。

  做一件事情,坑爹的不是不知道如何去做,而是每一步都照着别人的做,最终却没有像别人一样成功。而自己不得不去面对各种错误,但是成长的过程就是你遇到问题、遇到挫折,然后将问题解决的过程。所以,如果你编译不成功,试着去找出到底哪里出问题了,直到编译成功为止。我从发现问题到解决问题,用了差不多18个小时。所以,耐心点。

四)编译好的文件在哪里?

  参考中是说在Qt目录里,或者在“sqldrivers”目录里,这都是误导,我知道我编译成功了,但是我没找到文件,所以我就调用搜索文件的功能。最终,在“C:\Qt\Sources\qtbase\plugins\sqldrivers”目录下找到了我要的文件:

  

  将这四个文件复制,粘贴到所谓的Qt主目录“C:\Qt\Qt5.2.1\5.2.1\mingw48_32\plugins\sqldrivers”文件夹中。

  同时,将“E:\MySQL\lib”文件夹中的“libmysql.dll”文件拷贝到“C:\Qt\Qt5.2.1\5.2.1\mingw48_32\bin”文件夹中。

五)测试成果

  程序代码和输出结果如下:

  

Have fun!!!

Qt 5.2中编译加载MySQL数据库驱动问题的总结的更多相关文章

  1. 分享知识-快乐自己:Maven 无法加载 Oracle 数据库驱动源

    由于Oracle授权问题,Maven3不提供Oracle JDBC driver,为了在Maven项目中应用Oracle JDBC driver,必须手动添加到本地仓库. 手动添加到本地仓库需要本地有 ...

  2. sqoop加载mysql数据库

    ./bin/sqoop list-databases --connect jdbc:mysql://node-001:3306/ --username root --password hadoop

  3. 加载MySQL、Oracle、SQL Server 2000、SQL Server 2005及以上版本 的加载数据库驱动程序

    2018-11-04  20:00:59 开始 //getConnection(String url, String user, String password) //url:连接数据库的URL 3 ...

  4. 在java程序中使用JDBC连接mysql数据库

    在java程序中我们时常会用到数据库中的数据或操作数据库中的数据,如果java程序没有和我们得数据库连接,就不能实现在java程序中直接操作数据库.使用jdbc就能将java程序和数据库连起来,此时我 ...

  5. cocos2dx lua中异步加载网络图片,可用于显示微信头像

    最近在做一个棋牌项目,脚本语言用的lua,登录需要使用微信登录,用户头像用微信账户的头像,微信接口返回的头像是一个url,那么遇到的一个问题就是如何在lua中异步加载这个头像,先在引擎源码里找了下可能 ...

  6. Ubuntu16.04下的modules模块编译加载

    一.首先编写对应的驱动程序的相关内容:(最简单的hello.c程序) #include<linux/init.h> #include<linux/module.h> MODUL ...

  7. Qt之编译MySQL数据库驱动(MSVC)

    Qt之编译MySQL数据库驱动(MSVC) (2013-12-13 20:24:46) 转载▼ 标签: qt mysql qmysql qt编译mysql qt之msvc编译mysql 分类: Qt ...

  8. iOS 解决LaunchScreen中图片加载黑屏问题

    iOS 解决LaunchScreen中图片加载黑屏问题 原文: http://blog.csdn.net/chengkaizone/article/details/50478045 iOS 解决Lau ...

  9. 出现了内部错误-网站中X509Certificate2加载证书时出错

    今天给网站配置了加密证书文件,用类X509Certificate2加载证书文件时,一直报出现了内部错误,但是Demo中用控制台程序加载证书没任何问题 读取证书文件的语句: X509Certificat ...

随机推荐

  1. docker安装及卸载

    docker基本组成 镜像(image): docker镜像好比一个模板,可以通过这个模板创建容器服务,例如:tomcat镜像===>run===>tomcat01容器(提供服务器) 通过 ...

  2. Redis分布式锁 (图解-秒懂-史上最全)

    文章很长,而且持续更新,建议收藏起来,慢慢读! 高并发 发烧友社群:疯狂创客圈(总入口) 奉上以下珍贵的学习资源: 疯狂创客圈 经典图书 : 极致经典 + 社群大片好评 < Java 高并发 三 ...

  3. .NET Core/.NET5/.NET6 开源项目汇总5:权限管理系统项目

    系列目录     [已更新最新开发文章,点击查看详细] 企业管理系统一般包含后台管理UI.组织机构管理.权限管理.日志.数据访问.表单.工作流等常用必备功能.下面收集的几款优秀开源的管理系统,值得大家 ...

  4. Mysql8关于hashjoin的代码处理方式

    Mysql8关于hashjoin的代码处理方式 目录 Mysql8关于hashjoin的代码处理方式 1 表的Schema如下所示: 2 HashJoin代码实现 3 总结 1 表的Schema如下所 ...

  5. excel VBA把一个单元格内容按逗号拆分并依次替换到另一个单元格的括号里面(本题例子,把文本中的括号换成{答案}的格式,并按顺序填空)

    方法1:运用excel单元格拆分合并实现 思路:用VBA正则查询左侧括号个数,对右侧单元格逐一按逗号.顿号等符号分列,同时左侧按括号分列(分列只能按括号单边分列),分列完成后按要求合并,本题事例把括号 ...

  6. 40、Linux文件误删除恢复操作

    rm -rf / #此方法删除不了/目录: rm -rf /* #此方法可以删除/目录下的所有内容,禁止使用: 40.1.前言: 作为一个多用户.多任务的操作系统,Linux下的文件一旦被删除,是难以 ...

  7. 14、oracle sql语法

    14.0.注释: 1.单行注释:-- 2.多行注释:/* */ 14.1.sqlplus中的set指令: 1.设置每行显示的数据长度: SET LINESIZE 500; #有效范围是1-32767, ...

  8. JS刷新窗口的几种方式

    浮层内嵌iframe及frame集合窗口,刷新父页面的多种方法   <script language=JavaScript>       parent.location.reload(); ...

  9. LeSS 的诞生(一):大规模团队该何去何从

    <敏捷宣言>发布后,"敏捷"被越来越多的小型开发团队认可.与此同时,另一个问题也逐渐暴露了出来:以 Scrum 为首的敏捷方法论对那些大规模的开发团队并不友好. 基于此 ...

  10. nohup &的用法、进程查看以及终止

    p.p1 { margin: 0 0 2px; font: 16px ".PingFang SC" } p.p2 { margin: 0; font: 12px "Hel ...