qt 5.9.9连接mysql 8.0踩过的坑

在尝试使用Qt5.9.9连接MySQL8.0时遇到SSL连接错误,经过排查发现是版本不兼容问题。解决方案是降级至MySQL5.7,最终成功建立连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

qt 5.9.9连接mysql 8.0踩过的坑

最近需要qt连接mysql,于是去试了试。
博主看了很多博客,这是我的代码

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);

    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");

    db.setHostName("127.0.0.1");
    db.setDatabaseName("student");// 数据库名
    db.setUserName("root");// 用户名
    db.setPassword("123456");// 密码
    db.setPort(3306);// 端口号
    db.open();

    QSqlQuery query;
    query.exec("create table login(id varchar(30),password varchar(30));");

}

Widget::~Widget()
{
    delete ui;
}

此处要注意在.pro文件中改一下

QT       += core gui sql

运行结果为:
在这里插入图片描述
于是我将mysql/lib下的libmysql.dll和libmysql.lib文件拷贝到YOUR_QT_PATH/bin下。

结果错误没有变。于是,我改了一行代码看看错误原因

 qDebug() << "database connect is fail" << db.lastError().text();

错误代码为"SSL connection error: unknown error number QMYSQL: Unable to connect"
博主在网上搜了一下,发现是因为mysql 8.0和qt 5.9.9版本不匹配。必须是mysql 5.7。所以,只能把mysql 8.0卸掉,重新装mysql 5.7.
最后,我的qt终于连接上mysql了。
在这里插入图片描述

感动到哭~
最后,如果各位看官觉得有用,烦请点赞收藏,你的关注是我更新最大的动力

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值