前言:
使用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不能重复,否则插入失败,切记!!!