Qt 5.12.12 添加 mysql 支持

由于 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)

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值