QT5.14.2下使用MySQL遇到的问题及解决

项目场景:QT5.14.2下使用MySQL显示无驱动或驱动未连接异常解决

问题描述

`提示:QT5.14.2下可用驱动无QMYSQL

例如:
QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE QODBC QODBC3 QPSQL QPSQL7

原因分析:

提示:查看QT对应版本及编译器的plugins的sqldrivers目录下,是否含有qsqlmysql.dll和qsqlmysqld.dll驱动

解决方案:

提示:QT5.14.2版本下官方不再自带MySQL驱动,需要我们自己编译生成

1.下载MySqL,本人下载版本为mysql-8.0.30-winx64,特别提示8.3版本MYSQL不要再该版本QT下使用,部分接口不匹配,后续无法编译驱动
2.mysql下载链接 https://dev.mysql.com/downloads/mysql/
3.下载完成后解压,开始配置MySql服务参数,不需要MySQL服务该步骤可跳过
在这里插入图片描述在解压目录下,添加Data文件夹,添加my.ini文件,配置内容如上图所示,bind-Address = 127.0.0.1可不配置,配置可指定客户端连接IP

4.启动MySql服务,不需要MySQL服务该步骤可跳过
在这里插入图片描述本步骤CMD命令需使用管理员权限进行,进入MySQL的解压目录下,
(1)执行mysqld --initialize --console,记录初始密码,后面改密码使用;
(2)输入mysqld --install 将MySQL安装为windows服务,提示安装成功;
(3)执行 net start MySQL,启动MySQL服务;
(3)修改密码,输入mysqladmin -u root -p password,回车后,输入刚才记录的临时密码,再输入两次新密码;
(4)输入mysql -u root -p,回车后输入刚才修改的新密码,登录数据库;
(5)注意出现外部无法连接MySql情况,可能为赋权限,按照如下操作
若出现远程数据库访问失败的错误,以下为解决方法:
1)登入mysql服务器,通过命令: mysql -u root -p,回车后输入密码;
2)选择mysql数据库,通过命令:use mysql;
3)修改root用户的连接权限,执行命令:update user set host=’%’ where user=’root’;
4)如果修改完权限后你还是远程连接不上mysql数据库,那就是需要重启一下mysql服务器,执行命令:net stop mysql,服务停止后再执行 net start mysql 启动mysql服务,对应bind-Address改行注释掉或者0.0.0.0;

5.编译QT5.14.2对应版本驱动
找到源码路径在这里插入图片描述打开工程文件,按照下图配置

在这里插入图片描述添加MySql路径和lib到工程下,编译生成指定版本驱动

6.拷贝qsqlmysql.dll和qsqlmysqld.dll文件到对应编译器版本的plugins的sqldrivers(例:D:\QT5.14.2\5.14.2\msvc2017_64\plugins\sqldrivers)目录下;
拷贝MySql的bin目录下的libmysql.dll文件到对应编译器版本的bin(例:D:\QT5.14.2\5.14.2\msvc2017_64\bin)目录下;

解决MySql连接异常问题

1.因加密方式不同,导致的连接失败
QSqlError(1251, “QMYSQL: Unable to connect”, “Client does not support authentication protocol requested by server; consider upgrading MySQL client”)

mysql 8.0前加密方式为 mysql_native_password;8.0之后加密方式变更为caching_sha2_password;

解决方法:

  1. a.查看原用户加密方式
    在这里插入图片描述
    b.修改加密方式为mysql_native_password
    在这里插入图片描述
    c.查看修改加密结果
    在这里插入图片描述
  2. 添加对应加密方式新用户
    在这里插入图片描述
  • 33
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值