记录:编译Qt5.0连接MySql5.5数据库的驱动
第一步
1、准备好Mysql数据库安装文件,Qt5.0完整的离线安装包,以及Qt5.0的完整的源代码。安装好程序,假设Mysql的安装路径为:C:MySQL5.5,Qt5.0的安装路径:C:QtQt5.0.0-rc25.0.0-rc2,而Qt5.0的解压路径为:C:Qtqt-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:Qtqt-5.0.1-srcqtbasesrcpluginssqldriversmysql。具体的使用方式,我们在后面说明。
2、准备编译工作。选择开始->程序->Qt5.0.0-r2->5.0.0->MSVC2010->Qt5.0.0 for desktop(MSVC2010) prompt。我们在这个环境下使用qmake来生成编译程序的makefile文件。为什么要使用这个环境?因为,这个命令提示符已经为我们设置好了Qt库的环境,也即可以直接使用Qt库相关的工具。
第二步
(1)切换工作目录到:C:Qtqt-5.0.1-srcqtbasesrcpluginssqldriversmysql。可以看到如下的几个文件存在:
其中,mysql.pro就是所要的文件。所以的编译工作都是从这个文件开始。
(2)使用qmake生成makefile自动编译。注意大小写不能错。其中,include和Lib就是上面说的Mysql安装目录下的两个文件夹。如下图所示:
(3)如果一切顺利,将在当前目录生成几个makefile文件和两个文件夹。如下图:
(4)接下来是重要的一部。如果我们直接在当前窗口输入make进行编译工作,那么很可能会出错,如:
更改数不胜数。这个时候,我们可以换另外一种方法,用VS2010的命令行环境来进行编译工作,在开始菜单中选择vs2010的一个命令行环境,切换到当前的工作目录下,执行nmake命令:
果然,出错了!错误显示缺少某个头文件。实际上,我们去mysql的安装目录include文件夹下查看,明显是可以找到这样一个头文件的。那么,怎么办呢?可以在命令行中用/I指示搜索路径。但是我们还是用最笨最简单的方法。直接将mysql安装目录下的include文件夹拷贝到Qt5.0的安装路径下。按照出错的提示,具体路径为:C:QtQt5.0.0-rc25.0.0-rc2msvc2010includeQtSql。(这里注意,不是Qt5.0源码的路径哦,而是Qt5.0的安装路径。)如果一切顺利,我们就会得到几个lib文件和dll文件。文件位于:C:Qtqt-5.0.1-srcqtbasepluginssqldrivers。这个文件夹下的文件都是编译生成的新文件。我们将该目录下的qsqlmysql.dll和qsqlmysqld.dll拷贝到C:QtQt5.0.0-rc25.0.0-rc2msvc2010pluginssqldrivers目录下即可。配置工作至此完成。
第三步
连接。使用qt creator新建一个qt console项目,示例代码如下:
1 #include <QCoreApplication>
2 #include <QtSql/QSqlDatabase>
3 #include <QtSql/QSqlQuery>
4 #include <QDebug>
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()<<"true"<<endl;
20 ret = false;
21 QSqlQuery qsql(con);
22 ret = qsql.exec("SELECT * FROM userInfo COUNT(*)");
23 if(ret = true)
24 {
25 qDebug()<<"true"<<endl;
26 }
27 else
28 {
29 qDebug()<<"false"<<endl;
30 }
31 }
32 return a.exec();
33 }
输出结果:
至此,编译工作自此成功结束。
- github & CSRF
- 如何使用Python读取大文件
- 介绍一种非常好用汇总数据的方式GROUPING SETS
- 史上最大的CPU Bug(幽灵和熔断的OS&SQLServer补丁)
- 数据库副本的自动种子设定(自增长)
- Git 项目推荐 | 基于go+protobuff 实现的分布式
- ReflectASM-invoke,高效率java反射机制原理
- Web应用渗透测试-本地文件包含
- shiro权限控制(二):分布式架构中shiro的实现
- Groovy实现原理分析——准备工作
- HBCTF第一场2个pwn题的简单分析
- ACM竞赛之输入输出(以C与C++为例)
- 能让程序做的事情坚决不用人来做——批量修复markdownlint MD034警告
- swift demo1 tableview
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- 东京大学版「一生一芯」:自制CPU、C编译器,还成功运行了类Unix系统
- python实现将range()函数生成的数字存储在一个列表中
- Pytorch 使用不同版本的cuda的方法步骤
- CVE-2020-14645 Weblogic远程代码执行漏洞分析
- PaGoDo:一款功能强大的被动式Google Dork
- 微软轻量级系统监控工具sysmon原理与实现完全分析
- 用Windows电脑训练深度学习模型?超详细配置教程来了
- rConfig中的远程代码执行漏洞分析
- CVE-2020-9964:iOS中的信息泄露漏洞分析
- ReconSpider:一款功能强大的高级OSINT框架
- Python 3.9来了!这十个新特性值得关注
- IRFuzz:一款基于YARA规则的文档文件扫描工具
- 内网渗透测试研究:从NTDS.dit获取域散列值
- 腾讯云大禹高防IP之客户端获取真实IP
- 终极解密输入网址按回车到底发生了什么