登录
首页 >  数据库 >  MySQL

qt连接mysql

来源:SegmentFault

时间:2023-01-17 21:10:27 148浏览 收藏

对于一个数据库开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《qt连接mysql》,主要介绍了MySQL、qt5,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

环境

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,可以看到

clipboard.png

编辑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安装目录替换掉即可。

clipboard.png

打开qt自带的cmd窗口

clipboard.png

进入到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文件夹,会多出以下图中用红框圈出的文件

clipboard.png

在执行: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 
#include 
#include 

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() 

结果截图:

clipboard.png

文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《qt连接mysql》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>