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同学,看不懂的可以去看一看他的视频🐱?🏍!
|