Qt5.0编译mysql驱动_编译Qt5.0连接MySql5.5数据库的驱动(5.0版本的编译,我记得5.2开始自带了)...

本文详细介绍了如何在Qt5.0中编译连接MySQL5.5的驱动,包括准备Mysql和Qt5.0的安装文件、使用qmake生成makefile、解决编译错误以及最终的连接测试,确保Qt应用程序能成功访问MySQL数据库。
摘要由CSDN通过智能技术生成

第一步

1、准备好Mysql数据库安装文件,Qt5.0完整的离线安装包,以及Qt5.0的完整的源代码。安装好程序,假设Mysql的安装路径为:C:\MySQL5.5,Qt5.0的安装路径:C:\Qt\Qt5.0.0-rc2\5.0.0-rc2,而Qt5.0的解压路径为:C:\Qt\qt-5.0.1-src。

注意事项:(1)安装mysql数据库的时候,网上很多教程说要选择自定义安装,并把lib和include这个选项选上。其实这个并不重要。因为我机器上很久前装mysql时选的是typical安装的,在安装目录下仍然可以找到lib和include这两个文件夹。安装方式并不重要。(2)Qt5.0是Qt的最新版本,在网上找到的编译方法都是基于Qt4.x的。我这里下载的是qt-windows-opensource-5.0.0-rc2-msvc2010_32-x86-offline.exe。这个安装包使用的是VC编译环境。因此,接下来的编译工作都是使用VS编译工具来编译的。(3)为什么要下载Qt5.0的源代码(qt-everywhere-opensource-src-5.0.1.zip)?因为我们要编译Qt连接mysql的驱动程序,需要使用一个mysql.pro文件。这个文件就在Qt5.0源代码中。其路径为(源码包的解压路径):C:\Qt\qt-5.0.1-src\qtbase\src\plugins\sqldrivers\mysql。具体的使用方式,我们在后面说明。

2、准备编译工作。选择开始->程序->Qt5.0.0-r2->5.0.0->MSVC2010->Qt5.0.0 for desktop(MSVC2010) prompt。我们在这个环境下使用qmake来生成编译程序的makefile文件。为什么要使用这个环境?因为,这个命令提示符已经为我们设置好了Qt库的环境,也即可以直接使用Qt库相关的工具。

第二步

(1)切换工作目录到:C:\Qt\qt-5.0.1-src\qtbase\src\plugins\sqldrivers\mysql。可以看到如下的几个文件存在:

820318c4ac70fc8cfae6a0fd01965c06.png

其中,mysql.pro就是所要的文件。所以的编译工作都是从这个文件开始。

(2)使用qmake生成makefile自动编译。注意大小写不能错。其中,include和Lib就是上面说的Mysql安装目录下的两个文件夹。如下图所示:

5fa64b2341abaee32cb9ae23dbd6a272.png

(3)如果一切顺利,将在当前目录生成几个makefile文件和两个文件夹。如下图:

9f92cfc84a1fd9bfcd899125c0c9f202.png

(4)接下来是重要的一部。如果我们直接在当前窗口输入make进行编译工作,那么很可能会出错,如:

855e6ed1451b97e212f73c75fa96079b.png

更改数不胜数。这个时候,我们可以换另外一种方法,用VS2010的命令行环境来进行编译工作,在开始菜单中选择vs2010的一个命令行环境,切换到当前的工作目录下,执行nmake命令:

10074b0e2f7ccebeaf9042d16cd7ffff.png

果然,出错了!错误显示缺少某个头文件。实际上,我们去mysql的安装目录include文件夹下查看,明显是可以找到这样一个头文件的。那么,怎么办呢?可以在命令行中用/I指示搜索路径。但是我们还是用最笨最简单的方法。直接将mysql安装目录下的include文件夹拷贝到Qt5.0的安装路径下。按照出错的提示,具体路径为:C:\Qt\Qt5.0.0-rc2\5.0.0-rc2\msvc2010\include\QtSql。(这里注意,不是Qt5.0源码的路径哦,而是Qt5.0的安装路径。)如果一切顺利,我们就会得到几个lib文件和dll文件。文件位于:C:\Qt\qt-5.0.1-src\qtbase\plugins\sqldrivers。这个文件夹下的文件都是编译生成的新文件。我们将该目录下的qsqlmysql.dll和qsqlmysqld.dll拷贝到C:\Qt\Qt5.0.0-rc2\5.0.0-rc2\msvc2010\plugins\sqldrivers目录下即可。配置工作至此完成。

第三步

连接。使用qt creator新建一个qt console项目,示例代码如下:

48304ba5e6f9fe08f3fa1abda7d326ab.png

1 #include

2 #include

3 #include

4 #include

5

6 int main(int argc, char *argv[])

7 {

8 QCoreApplication a(argc, argv);

9

10 QSqlDatabase con = QSqlDatabase::addDatabase("QMYSQL");

11 con.setHostName("localhost");

12 con.setDatabaseName("kxdl");

13 con.setPort(3306);

14 con.setUserName("root");

15 con.setPassword("root");

16 bool ret = con.open();

17 if(ret)

18 {

19 qDebug()<

20 ret = false;

21 QSqlQuery qsql(con);

22 ret = qsql.exec("SELECT * FROM userInfo COUNT(*)");

23 if(ret = true)

24 {

25 qDebug()<

26 }

27 else

28 {

29 qDebug()<

30 }

31 }

32 return a.exec();

33 }

48304ba5e6f9fe08f3fa1abda7d326ab.png

输出结果:

36e1afb2f2ecd034f2f6217f22b210f1.png

至此,编译工作自此成功结束。

http://www.cnblogs.com/csuftzzk/archive/2013/05/04/3060212.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值