Qt 添加MySQL驱动教程 以及 操作数据库(增删查改)

前言:
使用MySQL数据库前我们必须添加MySQL驱动,有了驱动我们才能连接数据库,连接数据库成功后才能操作数据库(增删查改)。
Qt 添加MySQL驱动教程 如下(本人亲测成功版):

https://download.csdn.net/download/qq_42432673/88093467

在数据库中创建表,表结构如下:
在这里插入图片描述
现在驱动已经引入完成,数据库表也创建好了,下面我们开始写代码:

引入模块:

QT += core gui sql

mainwindow.h:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QDebug>

#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT
    
public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
    
    // 连接数据库
    void connectDataBase();
    // 查询操作
    void search();
    // 插入操作
    void insert();
    // 修改操作
    void update();
    // 删除操作
    void deleteData();
private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

mainwindow.cpp:

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

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    // 连接数据库
    connectDataBase();
    // 查询操作
    search();
    // 插入操作
    insert();
    // 修改操作
    update();
    // 删除操作
    deleteData();
}

MainWindow::~MainWindow()
{
    delete ui;
}
// 连接数据库
void MainWindow::connectDataBase()
{
    // 数据库类型
    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
    // 数据库主机地址
    db.setHostName("127.0.0.1"); 
    // 数据库用户名
    db.setUserName("root");
    // 数据库密码
    db.setPassword("123456");
    // 数据库名称
    db.setDatabaseName("practice");
    // 打开数据库
    if(false == db.open())
    {// 数据库打开失败
        qDebug()<<"数据库连接失败!!!";
        qDebug()<<db.lastError().text();
    }
    else
    {// 数据库打开成功
        qDebug()<<"success...";
    }
}
// 查询操作
void MainWindow::search()
{
    QString sql = "select * from user";
    QSqlQuery query;
    // 执行 sql 语句
    query.exec(sql);
    // 遍历完为 false
    while(query.next())
    {
        // 使用下标的方式查询表中数据
        qDebug()<<query.value(0).toInt()<<query.value(1).toString()<<query.value(2).toInt();
        // 使用字段的方式查询表中数据
        qDebug()<<query.value("id").toInt()<<query.value("name").toString()<<query.value("age").toInt();
    }
}
// 插入操作
void MainWindow::insert()
{
    // 注意:插入的主键(id)不能重复,否则插入失败
    QString sql = "insert into user(id,name,age) values(3,'小王',20)";
    QSqlQuery query;
    if(query.exec(sql))
    {
        // 数据插入成功
        qDebug()<<"insert success...";
    }
    else
    {
        // 数据插入失败
        qDebug()<<query.lastError().text();
    }
}
// 修改操作
void MainWindow::update()
{
    QString sql = "update user set name = '小张',age = 100 where id = 1";
    QSqlQuery query; 
    query.exec(sql);
}
// 删除操作
void MainWindow::deleteData()
{
    QString sql = "delete from user where id = 2";
    QSqlQuery query;
    query.exec(sql);
}

除了上面简单的增删查改以外,还可以多语句执行:

// 多语句执行
// 每条语句用分号隔开就可以同时执行多条语句
// 同时对表格进行增加、删除和更新操作
void MainWindow::multiQuery()
{
    QString sql = "insert into user(id,name,age) values(4,'小王',20);delete from user where id = 2;update user set name = '小张',age = 100 where id = 1;";
    QSqlQuery query;
    if(query.exec(sql))
    {
        // 执行成功
        qDebug()<<"multiQuery() success...";
    }
    else
    {
        // 执行失败
        qDebug()<<query.lastError().text();
    }
}

批处理执行(方法一):

// 批处理 方法一
// addBindValue()绑定值的顺序需要与 id、name、age 的顺序一致
void MainWindow::batchQuery()
{
    QSqlQuery query;
    // 待输入的值用通配符 “?” 代替
    query.prepare("insert into user(id,name,age) values(?,?,?)");
    
    // 创建 id 列表
    QVariantList idList;
    idList << 10 << 11 << 12;
    // 完成第一个 ? 的绑定
    query.addBindValue(idList); 
    
    // 创建 name 列表
    QVariantList nameList;
    nameList << "小明" << "小米" << "小艾";
    //完成第二个 ? 的绑定
    query.addBindValue(nameList);
    
    // 创建 age 列表
    QVariantList ageList;
    ageList << 18 << 19 << 20;
    // 完成第三个 ? 的绑定
    query.addBindValue(ageList);
    
    // 执行批处理
    query.execBatch();
}

批处理执行(方法二):

// 批处理 方法二
// 使用自定义的名称来完成绑定,这时绑定顺序可以自己决定
void MainWindow::batchQuery2()
{
    QSqlQuery query;
    // :id :name :age 是自定义的
    query.prepare("insert into user(id,name,age) values(:id,:name,:age)");
    
    // 创建 id 列表
    QVariantList idList;
    idList << 20 << 21 << 22;
    // 完成 :id 的绑定
    query.bindValue(":id",idList);
    
    // 创建 name 列表
    QVariantList nameList;
    nameList << "小明" << "小米" << "小艾";
    // 完成 :name 的绑定
    query.bindValue(":name",nameList);
    
    // 创建 age 列表
    QVariantList ageList;
    ageList << 18 << 19 << 20;
    // 完成 :age 的绑定
    query.bindValue(":age",ageList);

    //执行批处理
    query.execBatch();
}

一定要注意,插入数据的时候,主键id不能重复,否则插入失败,切记!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值