由于 Qt 5.12.12 有官方发布的离线安装包,对于使用 Qt 5 的用户来说,使用率还是比较高的。但是默认安装完成后,是没有 mysql 支持的,需要手动编译,添加对 mysql 的支持。
Qt 5.12.12 安装包 https://download.qt.io/archive/qt/5.12/5.12.12/qt-opensource-windows-x86-5.12.12.exe
安装时需要选择安装 Sources
安装好后,先建一个工程测试一下。
#include "widget.h"
#include "ui_widget.h"
#include "QtDebug"
#include "QSqlDatabase"
Widget::Widget(QWidget *parent)
: QWidget(parent)
, ui(new Ui::Widget)
{
ui->setupUi(this);
qDebug()<<"Support DB: "<<QSqlDatabase::drivers();
}
Widget::~Widget()
{
delete ui;
}
.pro 中需要增加 QT += sql
qDebug()<<"Support DB: "<<QSqlDatabase::drivers() 这行会打印出当前支持的数据库类型,可以看到并没有 mysql。
18:01:00: Debugging D:\QT\build-mysql-Desktop_Qt_5_12_12_MinGW_64_bit-Debug\debug\mysql.exe ...
Support DB: ("QSQLITE", "QODBC", "QODBC3", "QPSQL", "QPSQL7")
那下面来添加对 mysql 的支持。
理论上需要下载安装 mysql server,以获得其中的支持库。但实际上只要下载 MySQL Connector 就行,可以节省一些时间。
MySQL Connector https://downloads.mysql.com/archives/get/p/19/file/mysql-connector-c-6.1.11-winx64.zip
下载完成后,解压到 D:\ 备用 (D:\mysql-connector-c-6.1.11-winx64)。
通过开始菜单,打开 Qt 的命令行窗口 (Qt 5.12.12 (MinGW 7.3.0 64-bit))
依次输入:
cd ..\Src\qtbase\src\plugins\sqldrivers
qmake -- MYSQL_INCDIR=D:\mysql-connector-c-6.1.11-winx64\include MYSQL_LIBDIR=D:\mysql-connector-c-6.1.11-winx64\lib
make
如果没有安装 make,使用 mingw32-make
make install
如果没有错误发生,那么 Qt 对 mysql 的支持就添加完成了。
最后,不要忘记了还需要把 D:\mysql-connector-c-6.1.11-winx64\lib\libmysql.dll 复制到你的 .exe 目录下。
再运行一下之前建立的工程,可以看到已经有 mysql 的支持了。
18:25:30: Debugging D:\QT\build-mysql-Desktop_Qt_5_12_12_MinGW_64_bit-Debug\debug\mysql.exe ...
Support DB: ("QSQLITE", "QMYSQL", "QMYSQL3", "QODBC", "QODBC3", "QPSQL", "QPSQL7")
再来做下简单的查询测试
QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
db.setHostName("xxxxxxxxxx.com");
db.setPort(3306);
db.setDatabaseName("xxxxxxxx");
db.setUserName("xxxxxxxx");
db.setPassword("xxxxxxxx");
bool ok = db.open();
if (ok){
QSqlQuery query(db);
ok=query.exec(QString("select * from projects"));
if (ok){
while(query.next()){
qDebug()<< query.value("id").toInt()<< query.value("name").toString()<<query.value("customer").toString();
}
}
else{
qDebug()<< "Select error:" << query.lastError().text();
}
}
else {
qDebug()<<"Open error: "<<db.lastError().text();
}
Support DB: ("QSQLITE", "QMYSQL", "QMYSQL3", "QODBC", "QODBC3", "QPSQL", "QPSQL7")
1 "SensorCH4" "KD"
2 "RCU" "KD"
OK!
如果不想自己编译,可以下载编译好的dll (https://download.csdn.net/download/cole0809/88558465)