qt连接mysql4.7数据库_QT4.7访问MySQL的驱动编译过程

我们假设你已经成功安装了MySQL(我用的是MySQL的安装版)和QT,MySQL的安装路径采用的是其默认安装路径,也就是安装在了C:\Program Files下。下面开始正式讲解QT访问安装版MySQL的驱动的编译方法。

第一步:

因为MySQL的安装路径下有空格,而编译访问MySQL的驱动是不能有空格的,所以,我们先在C盘新建一个文件夹,命名为mysql,再将MySQL安装文件下的lib和include文件夹拷贝到刚才新建的那个文件夹下。

第二步:

打开打开QTCommand,我们可以看到起已经有一条默认路径,(因为我的是安装在D:\Qt文件夹下,所以默认路径为D:\Qt\4.7.3)

接着输入cd  C:\mysq\lib转到C:\mysq\lib库文件夹下

再输入reimp -d libmysql.lib (生成 libmysql.def文件)

接着输入dlltool -k -d libmysql.def -l libmysql.a (生成 libmysql.a文件),接着我们就可以看到出来了: libmysql.def  libmysql.a这两个文件。

第三步:

当我们准备好libmysql.a这个库文件之后,我们就可以开始编译之旅了。

我们输入cd %QTDIR%/src/plugins/sqldrivers/mysql,跳转到QT4.7的安装目录下的src/plugins/sqldrivers/mysql文件夹下(我的是D:\Qt\4.7.3\src\plugins\sqldrivers\mysql)

接着输入qmake -o Makefile "INCLUDEPATH+=C:/mysql/include" "LIBS+=C:/mysql/LIB/libmysql.a" mysql.pro

(此处特别小心,该路径指向的是我们自己在C盘创建的那个mysql文件夹,且libmysql.a得注意大小写的问题,否则会不成功),此时,我们得到了makefile,

接着输入make,此时D:\Qt\4.7.3\src\plugins\sqldrivers\mysql下的debug文件夹里边出现调试版本的了,也就是libqsqlmysqld4.a 和 qsqlmysqld4.dll

接着输入make release , 此时D:\Qt\4.7.3\src\plugins\sqldrivers\mysql下的release文件夹里边出现了release版本,也就是libqsqlmysql4.a 和 qsqlmysql4.dll

接着我们把生成的libqsqlmysqld4.a  qsqlmysqld4.dll  libqsqlmysql4.a  qsqlmysql4.dll 四个文件拷贝到QT的驱动目录下,即D:\Qt\4.7.3\plugins\sqldrivers目录下

最后我们再把mysql安装目录下lib文件中的libmysql.dll拷贝到QT安装目录下的bin文件夹中(否则会无法打开与数据库的连接)。

在文章的最后,可能会有一部分使用MyEclipse/Eclipse的人在使用QT时也去右键单击再添加库,最后安装以上方法编译成功了,该拷贝的也拷贝了,可就是会出现File Not Found的错误的,只需要在pro文件的最后,把因为右键单击添加库文件而自动增加的那几行代码删除就OK了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/541521.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

cellpadding_在CSS中设置cellpadding和cellspacing

cellpaddingIntroduction: 介绍: It is not unknown anymore that now and then we make use of tables in our web page or website, therefore we all are familiar with how to create tables or grids in our website or web page but there are times when we…

JavaScript中的arguments对象

JavaScript中的arguments对象 arguments 是一个类似数组的对象, 对应于传递给函数的参数。 语法 arguments 描述 arguments对象是所有函数中可用的局部变量。你可以使用arguments对象在函数中引用函数的参数。此对象包含传递给函数的每个参数的条目,第一个条目的索引…

mongodb 排序_技术分享 | MongoDB 一次排序超过内存限制的排查

本文目录:一、背景1. 配置参数检查2. 排序字段是否存在索引二、测试环境模拟索引对排序的影响1. 测试环境信息2. 报错语句的执行计划解释 3. 建立新的组合索引进行测试三、引申的组合索引问题1. 查询语句中,排序字段 _id 使用降序2. 查询语句中&#xff…

sim800 模式切换_SIM的完整形式是什么?

sim800 模式切换SIM:订户标识模块或订户标识模块 (SIM: Subscriber Identity Module or Subscriber Identification Module) SIM is an abbreviation of a Subscriber Identity Module or Subscriber Identification Module. SIM is a portable chip and an integra…

css新单位 vw , vh

考虑到未来响应式设计的开发,如果你需要,浏览器的高度也可以基于百分比值调整。但使用基于百分比值并不总是相对于浏览器窗口的大小定义的最佳方式,比如字体大小不会随着你窗口改变而改变,如今css3引入的新单位明确解决这一问题。…

linux下mysql目录结构_linux下mysql安装配置与目录结构

本节内容:linux下mysql安装与配置、mysql目录结构。1、准备安装程序(官方网站下载)服务端:MySQL-server-community-5.1.44-1.rhel4.i386.rpm客户端:MySQL-client-community-5.1.44-1.rhel4.i386.rpm2、安装(打印信息略) 代码示例:[rootlocalh…

Python字典values()方法与示例

字典values()方法 (Dictionary values() Method) values() method is used to get all values of a dictionary, it returns a view object that contains the all values of the dictionary as a list. values()方法用于获取字典的所有值,它返回一个包含字典所有值…

spark源码分析之Executor启动与任务提交篇

任务提交流程 概述 在阐明了Spark的Master的启动流程与Worker启动流程。接下继续执行的就是Worker上的Executor进程了,本文继续分析整个Executor的启动与任务提交流程Spark-submit 提交一个任务到集群通过的是Spark-submit通过启动脚本的方式启动它的主类&#xff0…

mysql 5.5.22.tar.gz_MySQL 5.5.22源码编译安装

MySQL 最新的版本都需要cmake编译安装,估计以后的版本也会采用这种方式,所以特地记录一下安装步骤及过程,以供参考。注意:此安装是默认CentOS下已经安装了最新工具包,比如GNU make, GCC, Perl, libncurses5-dev&#x…

Java Vector setElementAt()方法与示例

向量类setElementAt()方法 (Vector Class setElementAt() method) setElementAt() method is available in java.util package. setElementAt()方法在java.util包中可用。 setElementAt() method is used to set the given element (ele) at the given indices in this Vector.…

利用python进行数据分析D2——ch03IPython

为无为,事无事,味无味。大小多少,报怨以德。图难于其易,为大于其细;天下难事必作于易,天下大事必作于细。——老子关于图片的例子:import matplotlib.pyplot as plt imgplt.imread(ch03/stinkbug.png) import pylab plt.imshow(img) pylab.show()结果:调…

mysql 视图 字典_MySQL深入01-SQL语言-数据字典-服务器变量-数据操作DML-视图

SQL语言的组成部分常见分类:DDL:数据定义语言DCL:数据控制语言,如授权DML:数据操作语言其它分类:完整性定义语言:DDL的一部分功能约束约束:包括主键,外键,唯一…

为什么我会被淘汰?

这是一个值得讨论的问题。华为前段时间也传出了大规模裁员的一些负面新闻,一时间搞的人心惶惶。总结起来说,还是怕失去这份赖以生存的工作,尤其是对于上有老下有小的中年人来说,工作尤为重要。 淘汰,是软件行业不变的真…

Java Throwable initCause()方法与示例

Throwable类initCause()方法 (Throwable Class initCause() method) initCause() Method is available in java.lang package. initCause()方法在java.lang包中可用。 initCause() Method is used to instantiate the cause of this throwable to the given value and this met…

mysql 存储过程死循环_pl/sql存储过程loop死循环

今早,一个存储过程,写过很多次的存储过程,随手一写,各种报错,各种纠结,网上一搜,有好多个都遇到,论坛上给出的结局答案,今早,一个存储过程,写过很…

GATK之VariantAnnotator

VariantAnnotator 简要说明 用途: 利用上下文信息注释识别的变异位点(variant calls)分类: 变异位点操作工具概要: 根据变异位点的背景信息(与功能注释相对)进行注释。目前有许多的注释模块(见注释模块一节…

pipedreader_Java PipedReader connect()方法与示例

pipedreaderPipedReader类的connect()方法 (PipedReader Class connect() method) connect() method is available in java.io package. connect()方法在java.io包中可用。 connect() method is used to cause this PipedReader to be connected to the given PipedWriter (sou…

《Java学习指南》—— 1.4 设计安全

本节书摘来异步社区《Java学习指南》一书中的第1章,第1.4节,作者:【美】Patrick Niemeyer , Daniel Leuck,更多章节内容可以访问云栖社区“异步社区”公众号查看。 1.4 设计安全 Java被设计为一种安全语言,对于这一事实…

ppython_Python pcom包_程序模块 - PyPI - Python中文网

PCOM在python中一个非常基本的unitronics pcom协议实现。如何使用from pcom import commandsfrom pcom.plc import EthernetPlcwith EthernetPlc(address(192.168.5.43, 1616)) as plc:# Read realtime clockc commands.ReadRtc()res plc.send(c)print(res)# Set realtime cl…

bitcount方法详解_Java Long类的bitCount()方法和示例

bitcount方法详解长类bitCount()方法 (Long class bitCount() method) bitCount() method is available in java.lang package. bitCount()方法在java.lang包中可用。 bitCount() method is used to find the number of 1s bits in the 2s complement binary denotation of the…