IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Qt连接mysql报错QSqlDatabase: MYSQL driver not loaded -> 正文阅读

[大数据]Qt连接mysql报错QSqlDatabase: MYSQL driver not loaded

Qt连接Mysql的过程是:
Qt先连接Qt的Mysql插件,然后再连接到Mysql的动态库,然后再连接到Mysql
所以我们要有Qt的Mysql插件
这个插件再安装Qt时就可以选择安装
在这里插入图片描述
如果没有安装,可以考虑重新安装

重新安装后进入文件
D:\Qt5.9.9\5.9.9\Src\qtbase\src\plugins\sqldrivers\mysql
在这里插入图片描述
路径为自己安装Qt版本的路径
然后打开mysql.pro工程文件
在这里插入图片描述
在这里插入图片描述
然后
添加两行语句

win32:LIBS += -L D:/Mysql_connect/mysql-connector-c-6.1.11-win32/mysql-connector-c-6.1.11-win32/lib -llibmysql

INCLUDEPATH += D:/Mysql_connect/mysql-connector-c-6.1.11-win32/mysql-connector-c-6.1.11-win32/include

DEPENDPATH += D:/Mysql_connect/mysql-connector-c-6.1.11-win32/mysql-connector-c-6.1.11-win32/include

上面的路径不能有空格
路径就是mysql安装目录下的lib目录,然后再编译以下
可能有的小伙伴默认安装在了C盘的Program Files文件下,这样就会在选择路径时就会出现<mysql.h>is not found(我就是这样的🚗)
解决这个问题的方法:
https://downloads.mysql.com/archives/c-c/去下载mysql connect c即可
在这里插入图片描述
解压到不含空格路径的文件夹下
然后再将上面的路径换成自己的路径即可
后面两行时同名目录下的include文件夹,复制路径即可。
当上面的编译进行完成之后,再Qt安装的同名目录下会生成一个plugins文件夹,里面会多出两个文件
在这里插入图片描述

之后再将这两个文件拷贝到Qt中的,plugins文件夹中
在这里插入图片描述
然后再将mysql动态库中的libmysql文件拷贝到,Qt下的bin文件目录下
在这里插入图片描述
然后就开始测试可能会出现该错误"Authentication plugin 'caching_sha2_password' cannot be loaded: 找不到指定的模块。\r\nQMYSQL: Unable to connect"
原因是mysql0.0的再下载是你选择了新的登录验证,这个我们可以通过select表mysql.user来进行验证
在这里插入图片描述
解决这个问题的方法:
将用户密码登录验证换成native
在这里插入图片描述
上面的’root’@'localhost’根据你的电脑来进行设置,假如你的root的host是%则,将localhost换成%即可,最后要执行以下flush privileges;

#include "mainwindow.h"
#include "ui_mainwindow.h"

#include<QtDebug>
#include<QMessageBox>
#include<QSqlError>
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    connect(ui->pushButton,&QPushButton::clicked,this,[=](){
        QString userName;
        QString passWord;
        userName = ui->User_name->text();
        passWord = ui->password->text();
        this->ConnectDatabase(userName,passWord);
    });

}

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



bool MainWindow::ConnectDatabase(QString userName="root",QString passWord="root")
{
    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
    db.setHostName("127.0.0.1");
    db.setPort(3306);
    db.setDatabaseName("carlibrary");
	db.setUserName(userName.toUtf8().data());
    db.setPassword(passWord.toUtf8().data());
        bool ok = db.open();
        if (ok){
            qDebug()<<"Success Connect";
            return true;
        }
        else {
            qDebug()<<db.lastError().text();
           return false;
        }
}
void MainWindow::Select()
{
    QSqlQuery query;
    query.exec("select * from 用户");
    if(query.isActive())
    {
        qDebug()<<query.value(0).toString();
    }
    else
    {
        qDebug()<<"Select Error";
    }
}

在这里插入图片描述
连接成功

学习来源Yoe同学,看不懂的可以去看一看他的视频🐱?🏍!

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 20:57:41  更:2022-03-21 21:01:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 7:05:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码