环境
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();
}
结果截图: