Qt4.7.3(MinGW Opensource版)windows编译mysql驱动

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

 鉴于不少朋友索要这个mysql驱动,所以有了此文,授人鱼不如受之以渔。

网上此类帖子文章不少,但大家可能还是碰到这样那样的问题,今天我把我的编译经历尽量详细写出来,以便碰到同样问题时能够减少不必要的弯路。

首先说下我的环境:

 系统:windows xp sp3

QT : (Qt by Nokia v4.7.3 (MinGW OpenSource))

Mysql: 5.1社区版

MinGW用的QtCreator 2.2.1里带的mingw

PATH:

确保有D:\Qt\4.7.3\bin用的qmake.exe

C:\Qt\qtcreator-2.2.1\mingw\bin(mingw32,里面有gcc,g++,make工具和编译链接工具,离不了,呵呵)

d:\Program Files\MySQL\MySQL Server 5.1\bin 这下面有mysql动态库libmySQL.dll

定义了个环境变量QTDIR值D:\Qt\4.7.3表示qt的目录

 

首先注意mysql安装时不要用经典安装,选择完全安装或者自定义把头文件和库勾选上,这样安装后会有for c/c++的头文件和库目录:

 

因为这里我们使用MinGW来编译驱动,mysql提供的这个libmysql.lib我们还不能直接用(如果用微软的编译器就不用这样了),我们需要用个工具转成*.a来用。

工具下载:

 http://www.qtcn.org/download/mingw-utils-0.3.tar.gz

解压我们只用remip.exe这个东西,把他放在你的mingw/bin和那些make.exe放一起就行。

 


 
 
  1. cd D:\Program Files\MySQL\MySQL Server 5.1\lib\opt 
  2. 转到库目录 
  3. reimp -d libmysql.lib (生成 libmysql.def文件) 
  4. dlltool -k -d libmysql.def -l libmysql.a (生成 libmysql.a文件) 

 

over了,出来这2个东西了。

 

好了需要的kulibmysql.a准备好了

下面开始编译之旅:

来到qt mysql驱动的源程序目录,有个cpp文件和一个qt项目文件。

 

cd %QTDIR%/src/plugins/sqldrivers/mysql

当前目录转到源程序目录。


 
 
  1. qmake -o Makefile "INCLUDEPATH+=D:/Progra~1/MySQL/MySQLS~1.1/include" "LIBS+=D:/Progra~1/MySQL/MySQLS~1.1/LIB/OPT/libmysql.a" mysql.pro 
  2.  
  3. 得到makefile (注意libmysql.a这个大小写问题,否则会不成功)
  4.  
  5. make 
  6.  
  7. debug里出现了调试版本的了。 
  8.  
  9. make release 
  10.  
  11. release版本 

 

 

 

把这4个文件copy到你的qt驱动目录吧

 

下面来测试下:

 


 
 
  1. 头文件: 
  2.  
  3.  
  4. #ifndef PRODUCTVIEWERDIALOG_H 
  5. #define PRODUCTVIEWERDIALOG_H 
  6.  
  7. #include <QDialog> 
  8. #include <QSqlDatabase> 
  9.  
  10. #include "ui_productviewer.h" 
  11.  
  12. class ProductViewerDialog:public QDialog,public Ui::products 
  13.     Q_OBJECT 
  14. public
  15.     ProductViewerDialog(QWidget *parent=0); 
  16. private slots: 
  17.     void on_queryButton_clicked(); 
  18. private
  19.     QSqlDatabase db; 
  20. }; 
  21.  
  22. #endif // PRODUCTVIEWERDIALOG_H 
  23.  
  24. 源文件: 
  25.  
  26.  
  27. #include <QtGui> 
  28. #include <QSqlTableModel> 
  29.  
  30. #include "productviewerdialog.h" 
  31.  
  32. ProductViewerDialog::ProductViewerDialog(QWidget *parent):QDialog(parent) 
  33.     setupUi(this); 
  34.     this->db=QSqlDatabase::addDatabase("QMYSQL"); 
  35.     this->db.setHostName("127.0.0.1"); 
  36.     this->db.setUserName("root"); 
  37.     this->db.setPassword("123456"); 
  38.     this->db.setDatabaseName("nwind"); 
  39.  
  40. //点击查询 
  41. void ProductViewerDialog::on_queryButton_clicked() 
  42.     QSqlTableModel *mode  = new QSqlTableModel(this->tableView,this->db);  
  43.     if(this->db.open()) 
  44.     { 
  45.         mode->setTable("nwproducts"); 
  46.         this->tableView->setModel(mode); 
  47.         mode->select(); 
  48.     } 
  49.     else 
  50.     { 
  51.         QMessageBox::warning(this,tr("error"),tr("Database cannot be connected.")); 
  52.     } 
  53.  
  54. 程序入口: 
  55.  
  56.  
  57. #include <QtGui> 
  58. #include "productviewerdialog.h" 
  59.  
  60. //主函数  
  61. int main(int argc,char** argv){     
  62.     QApplication app(argc, argv); 
  63.     ProductViewerDialog dlg; 
  64.     dlg.show(); 
  65.     return app.exec(); 
  66. }     

 



 本文转自 xcf007 51CTO博客,原文链接:http://blog.51cto.com/xcf007/672917,如需转载请自行联系原作者


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
28天前
|
C++
vtkdicom0.8_vtk9.2_dcmtk3.6.7_qt6.2编译OK
本文介绍了如何编译整合VTK 9.2、DICOM 0.8、DCMTK 3.6.7和Qt 6.2的步骤,包括安装Qt、CMake配置以及确认相关路径和版本设置。
vtkdicom0.8_vtk9.2_dcmtk3.6.7_qt6.2编译OK
|
28天前
|
Unix 网络虚拟化 C++
VS2022+Qt5.14.2成功编译MITK2022.10
使用VS2022和Qt5.14.2成功编译MITK2022.10的过程,包括编译结果的截图、遇到的编译问题的解决方法、两个重要的注意事项(patch文件格式的修改和ITK-gitclone-lastrun文件的存在),以及参考链接。文中详细描述了如何解决编译过程中遇到的错误C2220和警告C4819,以及如何修改文件编码和尾行格式。
VS2022+Qt5.14.2成功编译MITK2022.10
|
14天前
|
Oracle 关系型数据库 MySQL
Mysql(1)—简介及Windows环境下载安装
MySQL 是一个流行的关系型数据库管理系统(RDBMS),基于 SQL 进行操作。它由瑞典 MySQL AB 公司开发,后被 Sun Microsystems 收购,现为 Oracle 产品。MySQL 是最广泛使用的开源数据库之一,适用于 Web 应用程序、数据仓库和企业应用。
46 2
|
28天前
|
计算机视觉
vs2019_qt6.2.4_dcmtk3.6.7_vtk9.2.2_itk5.3_opencv4.6.0编译记录
这篇文章记录了使用VS2019编译Qt6.2.4、DCMTK3.6.7、VTK9.2.2、ITK5.3和OpenCV4.6.0的过程,包括下载和编译步骤,并提供了遇到编译错误时的解决方案和参考链接。
vs2019_qt6.2.4_dcmtk3.6.7_vtk9.2.2_itk5.3_opencv4.6.0编译记录
|
28天前
|
C语言 C++ Windows
QT多插件通信框架CTK编译记录
本文记录了编译QT多插件通信框架CTK的过程,包括编译结果截图、部署配置、Log4Qt编译配置、参考链接和拓展资料。文中提供了详细的编译步骤和配置文件示例,以及相关的资源链接。
QT多插件通信框架CTK编译记录
|
28天前
|
机器学习/深度学习 Java 计算机视觉
opencv4.5.5+qt5.15.2+vtk9.1+mingw81_64编译记录
本文记录了使用mingw81_64编译OpenCV 4.5.5、Qt 5.15.2、VTK 9.1的详细过程,包括编译结果截图、编译步骤、遇到的问题及其解决方案,以及相关参考链接。文中还提到了如何编译boost源码为静态库,并提供了测试代码示例。
opencv4.5.5+qt5.15.2+vtk9.1+mingw81_64编译记录
|
28天前
|
C语言
BOOST1.75+QT5.15.2编译记录
本文记录了BOOST 1.75与Qt 5.15.2编译过程的详细步骤,包括编译结果截图、将boost源码编译为静态库的步骤,以及如何在Qt项目中使用BOOST库的测试代码。文章还提供了相关参考链接,以帮助解决在编译和使用过程中可能遇到的问题。
BOOST1.75+QT5.15.2编译记录
|
11天前
|
关系型数据库 MySQL Linux
Navicat 连接 Windows、Linux系统下的MySQL 各种错误,修改密码。
使用Navicat连接Windows和Linux系统下的MySQL时可能遇到的四种错误及其解决方法,包括错误代码2003、1045和2013,以及如何修改MySQL密码。
92 0
|
9天前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
43 6
|
7天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
37 3
Mysql(4)—数据库索引

推荐镜像

更多