Qt配置MySql数据库驱动(Windows)
1、前言
- 系统:windows10
- Qt版本:5.12.12
- 编译器:MinGW-64
- MySql开发包版本:6.1.11
2、安装MySql开发包
- 可以单独下载MySql开发包安装,也可以执行下载MySql安装包(里面包含了开发包);
2.1 MySql安装包
- MySql安装包比较大,如果觉得下载慢可用试试在linux下用下列命令下载;
wget -c https://dev.mysql.com/get/Downloads/MySQLInstaller/mysql-installer-community-8.0.29.0.msi
2.2 准备MySql开发库
- 进入MySql下载地址,在右上角可以看见有支持各种语言的开发包,这里选择C API;
- 根据说明可以看出如果要使用api 除了直接安装MySql外还可以在
MySql Product Archives
下载开发包;
- 网上很多人都喜欢下载安装包,这里选择压缩包更简单,我这里选择了64位压缩包;
- 下载后自己选择一个路径解压(后面会用到),解压后内容如下;
- 进入lib文件夹,内容如下,后面我们后用到
libmysql.lib
3、编译MySql驱动
- 找到自己Qt安装目录下的mysql驱动源码
D:\Qt\Qt5.12.12\5.12.12\Src\qtbase\src\plugins\sqldrivers
;
- 进入mysql目录,双击打开mysql.pro工程,然后注释掉
QMAKE_USE += mysql
;
- 点击浏览,找当之前解压开发包的位置,选择
libmysql.lib
,然后如图取消其它的所有勾选;
- 打开
qsqldriverbase.pri
文件,注释掉include($$shadowed($$PWD)/qtsqldrivers-config.pri)
,然后添加一行include(./configure.pri)
;
- 然后点击构建就可以了,注意这里选择的是MinGW 64编译器Release模式;
- 构建完成后就会生成如下4个库文件,但生成的库文件不在
build-mysql-Desktop_Qt_5_12_12_MinGW_64_bit-Release
文件夹中,可以使用Everything工具搜索文件在哪;
- 将这4个文件复制到qt安装路径下的
D:\Qt\Qt5.12.12\5.12.12\mingw73_64\plugins\sqldrivers
文件夹中(注意这里要和编译驱动时用的编译器版本相同,因为我使用的时MinGW64所以才是这个路径);
4、测试MySql驱动配置结果
- 新创建一个工程,在pro文件中加上
Qt += sql
; - 在main.cpp中使用
QSqlDatabase::drivers()
打印所有可用数据库驱动程序的列表; - 注意这里编译也是使用MinGW 64位编译器,其它编译器还没有配置;
#include <QSqlDatabase>
#include <QDebug>
#include <QApplication>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
qDebug()<<QSqlDatabase::drivers();
return a.exec();
}
("QSQLITE", "QODBC", "QODBC3", "QPSQL", "QPSQL7")
("QSQLITE", "QMYSQL", "QMYSQL3", "QODBC", "QODBC3", "QPSQL", "QPSQL7")
5、MSVC编译异常
- 我在使用
MSVC
编译器编译时发现mysql.pro加载不出来,并且编译会报如下错误:
:-1: error: Project ERROR: msvc-version.conf loaded but QMAKE_MSC_VER isn't set
- 这个问题很好解决,使用
Everything
软件搜索msvc-sersion.conf文件,找到使用的编译器路径下的那一个(这里我使用msvc2107-64);
- 使用文本编辑器打开后,根据里面msvc2017编译器对应的版本号在
msvc-version.conf
文件最前面加上一行QMAKE_MSC_VER=1909
;