qt连接mysql

719 查看

环境

win7 64位;qt5.6 mingw32;mysql5.6 32位
注意:qt和mysql的位数要一一对应,也就是32位对应32位,64位对应64位,编译驱动才没有问题,已经尝试qt32位对应mysql64位是编译驱动失败,qt64位对mysql32位没有试过

编译mysql驱动

1. 下载qt的源码

这里使用的qt是5.6.0版本,由于要编译的mysql驱动的源码是在qtbase下,所以只要下载qtbase部分的源码就行,下载地址是:http://download.qt.io/archive/qt/5.6/5.6.0/submodules/qtbase-opensource-src-5.6.0.zip
下载之后进行解压,这里的解压目录是:D:Qtqtbase-opensource-src-5.6.0

2. 进行编译

进入文件夹 D:Qtqtbase-opensource-src-5.6.0srcpluginssqldriversmysql,可以看到

编辑mysql.pro文件,引入相应mysql的库文件

INCLUDEPATH += "D:\MySQL\MySQL Server 5.6\include"
LIBS += "D:\MySQL\MySQL Server 5.6\lib\libmysql.lib"

D:MySQLMySQL Server 5.6是我的mysql的安装目录,用你的mysql安装目录替换掉即可。

打开qt自带的cmd窗口

进入到D:Qtqtbase-opensource-src-5.6.0srcpluginssqldriversmysql目录下

D:\Qt\Qt5.6.0\5.6\mingw49_32>pushd D:\Qt\qtbase-opensource-src-5.6.0\src\plugins
\sqldrivers\mysql

执行:qmake mysql.pro

D:\Qt\qtbase-opensource-src-5.6.0\src\plugins\sqldrivers\mysql>qmake mysql.pro

再看D:Qtqtbase-opensource-src-5.6.0srcpluginssqldriversmysql文件夹,会多出以下图中用红框圈出的文件

在执行:mingw32-make install

D:\Qt\qtbase-opensource-src-5.6.0\src\plugins\sqldrivers\mysql>mingw32-make install

如果看到以下输出信息,表明编译成功

copy /y ..\..\..\..\plugins\sqldrivers\qsqlmysqld.dll D:\Qt\Qt5.6.0\5.6\mingw49_
32\plugins\sqldrivers\qsqlmysqld.dll
已复制         1 个文件。
copy /y D:\Qt\qtbase-opensource-src-5.6.0\lib\cmake\Qt5Sql\Qt5Sql_QMYSQLDriverPl
ugin.cmake D:\Qt\Qt5.6.0\5.6\mingw49_32\lib\cmake\Qt5Sql
已复制         1 个文件。
mingw32-make[1]: Leaving directory 'D:/Qt/qtbase-opensource-src-5.6.0/src/plugin
s/sqldrivers/mysql'

3. 在自己的工程文件.pro中添加上:QT += sql

QT       += core gui sql

4. 测试

#include <QCoreApplication>
#include <QtSql/QSqlDatabase>
#include <QDebug>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL", "chat");
    db.setHostName("localhost");
    db.setDatabaseName("chat");
    db.setUserName("root");
    db.setPassword("123654");
    bool ok = db.open();
    qDebug() << "连接是否成功:" << ok;
    return a.exec();
}

结果截图: