视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Windows下编译Qt的Mysql驱动_MySQL
2020-11-09 19:33:38 责编:小采
文档


系统:Windows 7Qt版本:4.8.5Qt Creator版本:2.8.0 安装路径:Qt -> D:/Qt4.8.5Qt Creator -> D:/Qtcreator-2.8.0mingw -> D:/mingw 1.配置环境变量:到“我的电脑->属性->高级->环境变量->系统变量”中编辑Path,添加:我电脑的安装路 ;D:/Qt4.8.5/bin;D:/Qtcreator-2.8.0/bin;D:/mingw/bin确定;为了让环境变量生效,如果配置环境变量之前已经打开cmd,要重新打开一个新的cmd窗口。 2.下载mysql官网www.mysql.com下载,非安装包的文件名称类似这种格式:mysql-5.5.29-win32.zip只需要mysql里面的lib和include,解压到D:/ 3.下载mingw-utils-0.3.tar.gz解压出来,将bin文件夹里面的reimp.exe拷贝到D:/Qt/qtcreator-2.4.1/mingw/bin目录,不拷贝也行,调用reimp手动添加绝对路径。 4.编译驱动打开cmd,执行以下命令:(1)转换libmysql格式cd d:/mysql/libreimp -d libmysql.libdlltool -k -d libmysql.def -l libmysql.a(2)编译qt的mysql驱动cd d:/Qt4.8.0/src/plugins/sqldrivers/mysqlqmake "CONFIG+=release" -o Makefile "INCLUDEPATH+=d:/mysql/include" "LIBS+=d:/mysql/lib/libmysql.a" mysql.promingw32-makeqmake "CONFIG+=debug" -o Makefile "INCLUDEPATH+=d:/mysql/include" "LIBS+=d:/mysql/lib/libmysql.a" mysql.promingw32-make 5.拷贝mysql驱动编译完成后,打开D:/Qt4.8.0/src/plugins/sqldrivers/mysql目录,可以看到release和debug目录,分别从release和debug目录中拷贝以下4个文件到D:/Qt4.8.0/plugins/sqldrivers:qsqlmysql4.dlllibqsqlmysql4.aqsqlmysqld4.dlllibqsqlmysqld4.a 6.拷贝mysql动态库(重要)(1)本机运行拷贝D:/mysql/lib/libmysql.dll文件到D:/Qt4.8.0/bin (2)发布应用程序没有mysql的电脑,若要发布应用程序,要跟着libmysql.dll一块发布,与应用程序同级目录。 7.测试mysql可用性加入已经存在mysql服务,那么编写以下代码测试:(1).测试是否有驱动QStringList driverList = QSqlDatabase::drivers(); qDebug() << driverList; 运行结果:("QSQLITE", "QMYSQL3", "QMYSQL", "QODBC3", "QODBC")? 如果存在QMYSQL和QMYSQL3就是正确的(2).测试mysql是否可用QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); db.setDatabaseName("testsql"); bool ok = db.open(); qDebug() << ok; 运行结果:true 若为true,说明连接成功

下载本文
显示全文
专题