前言:
使用MySQL數(shù)據(jù)庫前我們必須添加MySQL驅(qū)動,有了驅(qū)動我們才能連接數(shù)據(jù)庫,連接數(shù)據(jù)庫成功后才能操作數(shù)據(jù)庫(增刪查改)。
Qt 添加MySQL驅(qū)動教程 如下(本人親測成功版):
https://download.csdn.net/download/qq_42432673/88093467
在數(shù)據(jù)庫中創(chuàng)建表,表結(jié)構(gòu)如下:
現(xiàn)在驅(qū)動已經(jīng)引入完成,數(shù)據(jù)庫表也創(chuàng)建好了,下面我們開始寫代碼:
引入模塊:
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();
// 連接數(shù)據(jù)庫
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);
// 連接數(shù)據(jù)庫
connectDataBase();
// 查詢操作
search();
// 插入操作
insert();
// 修改操作
update();
// 刪除操作
deleteData();
}
MainWindow::~MainWindow()
{
delete ui;
}
// 連接數(shù)據(jù)庫
void MainWindow::connectDataBase()
{
// 數(shù)據(jù)庫類型
QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
// 數(shù)據(jù)庫主機(jī)地址
db.setHostName("127.0.0.1");
// 數(shù)據(jù)庫用戶名
db.setUserName("root");
// 數(shù)據(jù)庫密碼
db.setPassword("123456");
// 數(shù)據(jù)庫名稱
db.setDatabaseName("practice");
// 打開數(shù)據(jù)庫
if(false == db.open())
{// 數(shù)據(jù)庫打開失敗
qDebug()<<"數(shù)據(jù)庫連接失?。。。?;
qDebug()<<db.lastError().text();
}
else
{// 數(shù)據(jù)庫打開成功
qDebug()<<"success...";
}
}
// 查詢操作
void MainWindow::search()
{
QString sql = "select * from user";
QSqlQuery query;
// 執(zhí)行 sql 語句
query.exec(sql);
// 遍歷完為 false
while(query.next())
{
// 使用下標(biāo)的方式查詢表中數(shù)據(jù)
qDebug()<<query.value(0).toInt()<<query.value(1).toString()<<query.value(2).toInt();
// 使用字段的方式查詢表中數(shù)據(jù)
qDebug()<<query.value("id").toInt()<<query.value("name").toString()<<query.value("age").toInt();
}
}
// 插入操作
void MainWindow::insert()
{
// 注意:插入的主鍵(id)不能重復(fù),否則插入失敗
QString sql = "insert into user(id,name,age) values(3,'小王',20)";
QSqlQuery query;
if(query.exec(sql))
{
// 數(shù)據(jù)插入成功
qDebug()<<"insert success...";
}
else
{
// 數(shù)據(jù)插入失敗
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);
}
除了上面簡單的增刪查改以外,還可以多語句執(zhí)行:
// 多語句執(zhí)行
// 每條語句用分號隔開就可以同時執(zhí)行多條語句
// 同時對表格進(jìn)行增加、刪除和更新操作
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))
{
// 執(zhí)行成功
qDebug()<<"multiQuery() success...";
}
else
{
// 執(zhí)行失敗
qDebug()<<query.lastError().text();
}
}
批處理執(zhí)行(方法一):
// 批處理 方法一
// addBindValue()綁定值的順序需要與 id、name、age 的順序一致
void MainWindow::batchQuery()
{
QSqlQuery query;
// 待輸入的值用通配符 “?” 代替
query.prepare("insert into user(id,name,age) values(?,?,?)");
// 創(chuàng)建 id 列表
QVariantList idList;
idList << 10 << 11 << 12;
// 完成第一個 ? 的綁定
query.addBindValue(idList);
// 創(chuàng)建 name 列表
QVariantList nameList;
nameList << "小明" << "小米" << "小艾";
//完成第二個 ? 的綁定
query.addBindValue(nameList);
// 創(chuàng)建 age 列表
QVariantList ageList;
ageList << 18 << 19 << 20;
// 完成第三個 ? 的綁定
query.addBindValue(ageList);
// 執(zhí)行批處理
query.execBatch();
}
批處理執(zhí)行(方法二):文章來源:http://www.zghlxwxcb.cn/news/detail-605465.html
// 批處理 方法二
// 使用自定義的名稱來完成綁定,這時綁定順序可以自己決定
void MainWindow::batchQuery2()
{
QSqlQuery query;
// :id :name :age 是自定義的
query.prepare("insert into user(id,name,age) values(:id,:name,:age)");
// 創(chuàng)建 id 列表
QVariantList idList;
idList << 20 << 21 << 22;
// 完成 :id 的綁定
query.bindValue(":id",idList);
// 創(chuàng)建 name 列表
QVariantList nameList;
nameList << "小明" << "小米" << "小艾";
// 完成 :name 的綁定
query.bindValue(":name",nameList);
// 創(chuàng)建 age 列表
QVariantList ageList;
ageList << 18 << 19 << 20;
// 完成 :age 的綁定
query.bindValue(":age",ageList);
//執(zhí)行批處理
query.execBatch();
}
一定要注意,插入數(shù)據(jù)的時候,主鍵id不能重復(fù),否則插入失敗,切記?。?!文章來源地址http://www.zghlxwxcb.cn/news/detail-605465.html
到了這里,關(guān)于Qt 添加MySQL驅(qū)動教程 以及 操作數(shù)據(jù)庫(增刪查改)的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!