QT 连接MySQL

QT 连接MySQL

QT 版本:x86 5.12.6

MySQL版本:x64 8.0.27

注意事项:安装MinGW 必须与MySQL版本一致,即都为x86或x64,文中目录以实际安装地址为准

  1. 安装完成后,复制MySQL文件 lib目录下libmysql.dll,libmysql.lib 到"D:\QT\5.12.6\mingw73_64\bin"目录
    在这里插入图片描述
    在这里插入图片描述
  1. 在QT目录下找到mysql文件,用QT打开

“D:\QT\5.12.6\Src\qtbase\src\plugins\sqldrivers\mysql\mysql.pro”

修改

\#QMAKE_USE += mysql

添加

INCLUDEPATH += "D:/MySQL/include"

LIBS += "D:/MySQL/lib/libmysql.lib"

DESTDIR = ../mysql/lib/

在这里插入图片描述

  1. 在D盘会出现plugins文件夹,将复制到"D:\QT\5.12.6\mingw73_64\plugins\sqldrivers"文件夹中即可
    在这里插入图片描述
    在这里插入图片描述
    测试代码:
    借鉴作者:Tinkle02
// mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <iostream>
#include <QMainWindow>
#include <QSqlDatabase>
#include <QDebug>
#include <QMessageBox>
#include <QSqlError>
#include <QSqlQuery>
using namespace std;
QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE
class MainWindow : public QMainWindow
{
    Q_OBJECT
public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
    void connectMYSQL();
    void createDB();
    void initDB();
    QSqlDatabase database;
private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H
// main.cpp
#include "mainwindow.h"

#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    MainWindow w;
    w.show();
    qDebug()<<QSqlDatabase::drivers();
    w.connectMYSQL();
    w.createDB();
    w.initDB();
    return a.exec();
}
// mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"

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

}
//连接数据库
void MainWindow::connectMYSQL()
{
    cout<<"connect is enter"<<endl;
    if (QSqlDatabase::contains("testConnect"))//判断testConnect连接是否存在并连接
    {
        std::cout<<"connect is run......"<<std::endl;
        database = QSqlDatabase::database("testConnect");
    }
    else //未连接则新建数据库连接
    {
        database=QSqlDatabase::addDatabase("QMYSQL","testConnect");//创建数据库连接,并为其命名testConnect
        database.setHostName("localhost");      //连接数据库主机名,这里需要注意(若填的为”127.0.0.1“,出现不能连接,则改为localhost)
        database.setPort(3306);                 //连接数据库端口号,与设置一致
        database.setUserName("root");          //数据库用户名,与设置一致
        database.setPassword("muzuki");    //数据库密码,与设置一致
    }
    if(!database.open())
    {
        qDebug()<<"fail to connect mysql:"<<database.lastError().text();
        return;
    }
}

//创建数据库、数据表
void MainWindow::createDB()
{
    QString querystring;
    //创建数据库
    database = QSqlDatabase::database("testConnect");
    querystring = "CREATE DATABASE IF NOT EXISTS student_info";
    database.exec(querystring);
    if (database.lastError().isValid())
    {
        qDebug()<<"Create database failed."<<database.lastError();
        return;
    }


    //创建数据表student
    database.setDatabaseName("student_info");
    if(!database.open())
    {
        qDebug()<<"database open failed";
        return;
    }

    querystring =
            "CREATE TABLE IF NOT EXISTS student_info.Student\
            (\
                Name varchar(20),\
                NO varchar(20) primary key,\
                Sex varchar(20),\
                Tell varchar(20),\
                Address varchar(30), \
                Hobbies varchar(30)\
                )";
            database.exec(querystring);//执行创建数据表语句
    if (database.lastError().isValid())
    {
        qDebug()<<"Student table creat failed:" << database.lastError();
        return;
    }

    //支持中文
    database.exec("alter table Student convert to character set utf8");

}

//初始化数据库(添加原始值)
void MainWindow::initDB()
{
    QSqlQuery query(database);
    query.exec("insert into Student values('张三', '2018010235', '男','12116588966','北京市朝阳区幸福小区12#103','篮球,游泳')");
    query.exec("insert into Student values('李四', '2018020156', '男','15665487200','湖南省长沙市岳麓区开心小区9#602','足球')");
    query.exec("insert into Student values('灵儿', '2018020202', '女','10202020202','江苏省南京市玄武区爱情公寓2#202','Dota')");
    if(!query.exec())
    {
        qDebug() << "Error: Fail to insert ." << query.lastError();

    }

}

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


若依旧无法连接数据库,经过测试可能是未将MySQL/bin目录下添加至PATH变量

    1. 在环境变量中添加如下变量,根据实际安装地址
      在这里插入图片描述
    1. 将bin目录添加至Path中即可
      在这里插入图片描述
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Qt连接MySQL数据库,需要安装MySQL驱动程序。以下是连接MySQL数据库的步骤: 1. 安装MySQL驱动程序 在Qt连接MySQL数据库,需要安装Qt提供的MySQL驱动程序。可以使用Qt Maintenance Tool来安装MySQL驱动程序。打开Qt Maintenance Tool,选择“添加或删除组件”,找到“Qt版本->Qt->Qt 5.x->Qt 5.x MySQL”,然后选择安装。 2. 引入MySQL头文件 在Qt代码中,需要引入MySQL头文件,包括<QSqlDatabase>、<QSqlQuery>和<QSqlError>。可以使用以下代码引入这些头文件: ```c++ #include <QSqlDatabase> #include <QSqlQuery> #include <QSqlError> ``` 3. 连接MySQL数据库 使用以下代码连接MySQL数据库: ```c++ QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); db.setHostName("localhost"); // 设置主机名 db.setPort(3306); // 设置端口号 db.setDatabaseName("database_name"); // 设置数据库名 db.setUserName("username"); // 设置用户名 db.setPassword("password"); // 设置密码 if (!db.open()) { qDebug() << "Failed to connect to database:" << db.lastError().text(); } ``` 其中,QSqlDatabase::addDatabase()函数设置MySQL数据库驱动程序,其参数为“QMYSQL”。然后,设置主机名、端口号、数据库名、用户名和密码,并调用QSqlDatabase的open()函数连接MySQL数据库。如果连接失败,可以使用db.lastError().text()来获得错误信息。 4. 执行SQL查询 连接MySQL数据库后,可以使用以下代码执行SQL查询: ```c++ QSqlQuery query; if (!query.exec("SELECT * FROM table_name")) { qDebug() << "Failed to execute query:" << query.lastError().text(); } while (query.next()) { // 处理结果集 } ``` 其中,QSqlQuery对象用于执行SQL查询,其exec()函数执行查询,next()函数用于遍历结果集。 以上就是Qt连接MySQL数据库的基本步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值