QT编译mysql驱动

一、 下载mysql C链接库

地址:http://dev.mysql.com/downloads/

根据当前系统选择下载:

二、 安装下载好的mysql驱动文件

注意,一定要安装在不含有中文、空格以及特出符号的文件、路径中,为了方面起见,我直接安装在了 E:\MySQL 目录下,建议这么做。

一定要选择第二项,否者我们没法指定安装目录,会默认安装到C盘下。不过后来证明安装到哪里都无所谓,但这里作为一个安装mysql的知识点吧,因为在安装mysql server时一样可以通过这种方式选择安装路径。

安装目录如下:

三、 库文件拷贝

我的QT 安装目录为 E:\QT4\4.8.4,版本号是4.8.4 所以打开如下目录:

E:\QT4\4.8.4\src\plugins\sqldrivers\mysql,内容如下:

进入mysql 驱动安装目录下的lib目录:

将libmysql.dll 和 libmysql.lib 文件即上图圈出的文件拷贝到

E:\QT4\4.8.4\src\plugins\sqldrivers\mysql 目录下:

四、 正式编译驱动

编辑目录下的mysql.pro文件,添加:

INCLUDEPATH+="E:\MySQL\include"

LIBS+=-LE:\MySQL\lib\ -llibmysql

图中圈中的目录为mysql驱动安装的目录,这个一定不能写错。

运行qt的控制台窗口,进行文件的编译。Qt控制台打开方法如下:

控制台如下:

切换到 E:\QT4\4.8.4\src\plugins\sqldrivers\mysql目录,

输入:cd E:\QT4\4.8.4\src\plugins\sqldrivers\mysql

执行qmake

执行mingw32-make debug ,生成debug版本的链接库:

成功生成:

执行mingw32-make release,生成release版本的链接库:

成功生成:

在E:\QT4\4.8.4\src\plugins\sqldrivers\mysql项目目录下会生成如下文件:

分别进入debug与release目录,会看到生成的

qsqlmysqld4.dll、qsqlmysqld4.lib 和 qsqlmysql4.dll、qsqlmysql4.lib 链接库文件。

将这4个文件拷贝到E:\QT4\4.8.4\plugins\sqldrivers 目录下:

将之前拷贝到项目目录下的libmysql.dll 和 libmysql.lib文件拷贝到C:\Windows\System32目录下。

这样mysql驱动边完全安装完成。以上编译过程也可以用qt creator 来完成,与编译普通的qt项目没有区别。

五、 测试连接mysql

下面做一个测试程序,新建控qt制台项目,main.cpp 文件内容如下:

源码:

  
 1 #include <QCoreApplication>
 2 #include <QDebug>
 3 #include <QString>
 4 #include <QStringList>
 5 #include <QtSql/QtSql>
 6 #include <QtSql/QSqlDatabase>
 7  
 8  
 9 int main(int argc, char *argv[])
10 {
11     QCoreApplication a(argc, argv);
12  
13     qDebug() << "Available drivers:";
14  
15     QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");
16  
17     db.setHostName("127.0.0.1");
18     db.setPort(3306);
19     db.setDatabaseName("mysql");
20     db.setUserName("root");
21     db.setPassword("qaz");
22  
23     if(db.open()){
24         qDebug() <<"success to link mysqld db!";
25     }
26  
27     return a.exec();
28 }

 

运行结果如下:

这样便证明mysql安装完毕,Enjoy!

参考:http://jingyan.baidu.com/article/27fa7326ffb99146f8271fe0.html

QT编译mysql驱动,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。