在Qt中操作MySQL數(shù)據(jù)庫的實(shí)戰(zhàn)指南
一、安裝驅(qū)動
(1)安裝
在Qt中操作MySQL數(shù)據(jù)庫首先要安裝mysql的驅(qū)動文件,將MySQL下的libmusql.dll文件復(fù)制到Qt的安裝路徑下的bin文件夾下即可。

直接將libmysql.dll文件粘貼到此文件夾中。

(2)驗(yàn)證驅(qū)動是否安裝成功
復(fù)制成功之后來測試一下驅(qū)動程序是否安裝成功,新建一個(gè)文件,選擇Qt設(shè)計(jì)師界面類,后面的操作都保持默認(rèn)即可。

在新生成的.cpp文件中引入以下庫
#include <QSqlDatabase> #include <QDebug> #include <QMessageBox> #include <QSqlError> #include <QString> #include <QSqlQuery> #include <QVariantList>
在構(gòu)造函數(shù)中插入以下代碼,然后點(diǎn)擊運(yùn)行,如果不彈出警告窗口則說明安裝成功,否則就是失敗了。
//添加一個(gè)數(shù)據(jù)庫
QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL"); //括號內(nèi)要寫出數(shù)據(jù)庫的類型
//設(shè)置數(shù)據(jù)庫
db.setHostName("127.0.0.1"); //設(shè)置數(shù)據(jù)庫的主機(jī)ip
//設(shè)置數(shù)據(jù)庫的用戶名
db.setUserName("root");
//設(shè)置數(shù)據(jù)庫的密碼
db.setPassword("123456"); //這個(gè)就是安裝MySQL時(shí)設(shè)置的密碼
//設(shè)置數(shù)據(jù)庫的名字
db.setDatabaseName("aaa2");
//打開數(shù)據(jù)庫(已經(jīng)安裝過mysql驅(qū)動了)
if(db.open()==false){
QMessageBox::warning(this,"waring",db.lastError().text());
}二、使用MySQL數(shù)據(jù)庫
(1)單語句執(zhí)行
首先創(chuàng)建一個(gè)QString對象sql,將要執(zhí)行的語句寫在 sql中,然后創(chuàng)建QSqlQuery類的對象query,調(diào)用其exec()函數(shù)執(zhí)行sql中的代碼。
QString sql = "insert into student (id,name,age,math) values (1,'kaw',20,97)"; //書寫想要執(zhí)行的語句
QSqlQuery query; //創(chuàng)建一個(gè)QSqlQuery對象
query.exec(sql); //執(zhí)行mysql語句(2)多語句執(zhí)行
在sql中,每條語句用分號隔開就可以同時(shí)執(zhí)行多條語句了。下面同時(shí)對表格進(jìn)行增加、刪除和更新操作。
QString sql = "insert into student (id,name,age,math) values (13,'kaw',20,97);delete from student where id=2;update student set name='sdd',math=100 where id=10;";
QSqlQuery query; //創(chuàng)建一個(gè)QSqlQuery對象
query.exec(sql); //執(zhí)行mysql語句(3)批處理操作
方式一:addBindValue()
在query.prepare()中輸入自己想要執(zhí)行的語句,其中待輸入的值用“?”代替,在這里“?”就是通配符。后面再用idList、nameList、ageList和mathList添加自己想要設(shè)置的值。注意,addBindValue()綁定值的順序需要與id、name、age、math的順序一致。
QSqlQuery query;
query.prepare("insert into student (id,name,age,math) values (?,?,?,?)"); //書寫語句模型
//添加綁定數(shù)據(jù)
QVariantList idList; //創(chuàng)建一個(gè)id列表
idList << 15<<16<<17;
query.addBindValue(idList); //完成第一個(gè)?的綁定
QVariantList nameList;
nameList << "ddd"<<"eee"<<"jjj";
query.addBindValue(nameList); //完成第二個(gè)?的綁定
QVariantList ageList;
ageList << 25<<24<<23;
query.addBindValue(ageList); //完成第三個(gè)?的綁定
QVariantList mathList;
mathList << 90<<89<<90;
query.addBindValue(mathList); //完成第四個(gè)?的綁定
//執(zhí)行批處理
query.execBatch();方式二:bindValue()
直接用自定義的名稱來完成綁定,這時(shí)綁定順序可以自己決定。
QSqlQuery query;
query.prepare("insert into student (id,name,age,math) values (:id,:name,:age,:math)"); //:id之類的名字時(shí)自定義的 自己方便就好
//添加綁定數(shù)據(jù)
QVariantList idList; //創(chuàng)建一個(gè)id列表
idList << 18<<19<<20;
query.bindValue(":id",idList); //完成:id的綁定
QVariantList nameList;
nameList << "ddd"<<"eee"<<"jjj";
query.bindValue(":name",nameList); //完成:name的綁定
QVariantList ageList;
ageList << 25<<24<<23;
query.bindValue(":age",ageList); //完成:age的綁定
QVariantList mathList;
mathList << 90<<89<<90;
query.bindValue(":math",mathList); //完成:math的綁定
//執(zhí)行批處理
query.execBatch();(4)查詢
要查詢的表為:

value后的值可以是索引,也可以是列名。取出后需要將其轉(zhuǎn)為對應(yīng)的數(shù)據(jù)類型。
//查詢操作
QSqlQuery query;
query.exec("select * from student");
while(query.next()){
qDebug()<<query.value(0).toInt()
<<query.value("name").toString().toUtf8().data()
<<query.value(2).toInt()
<<query.value(3).toInt();
}查詢結(jié)果:

三、總結(jié)
啊啊啊啊,自己太菜了,看啥啥不會真是麻了。今天剛開始接觸MySQL數(shù)據(jù)庫,感覺就是操作很方便、功能很強(qiáng)大、難度也不下。
到此這篇關(guān)于在Qt中操作MySQL數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)Qt操作MySQL數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例
這篇文章主要介紹了MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下2020-12-12
MYSQL使用.frm恢復(fù)數(shù)據(jù)表結(jié)構(gòu)的實(shí)現(xiàn)方法
在這里我們探討使用.frm文件恢復(fù)數(shù)據(jù)表機(jī)構(gòu)(當(dāng)然如果你以前備份過數(shù)據(jù)表,你可以使用調(diào)用備份的數(shù)據(jù)表)2010-02-02
mysql 5.7.21 解壓版通過歷史data目錄恢復(fù)數(shù)據(jù)的教程圖解
本文通過圖文并茂的形式給大家介紹了mysql 5.7.21 解壓版,通過歷史data目錄恢復(fù)數(shù)據(jù)的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
MySQL時(shí)間盲注的五種延時(shí)方法實(shí)現(xiàn)
MySQL時(shí)間盲注主要有五種,sleep(),benchmark(t,exp),笛卡爾積,GET_LOCK() RLIKE正則,本文就主要介紹了這五種方法,感興趣的可以了解一下2021-05-05
MySQL查詢表中重復(fù)數(shù)據(jù)的實(shí)現(xiàn)
在數(shù)據(jù)庫中,我們經(jīng)常需要查詢重復(fù)字段來確保數(shù)據(jù)的準(zhǔn)確性,如果數(shù)據(jù)中有重復(fù)字段,則可能會導(dǎo)致查詢結(jié)果錯(cuò)誤,本文就想詳細(xì)的介紹了MySQL查詢表中重復(fù)數(shù)據(jù),感興趣的可以了解一下2023-08-08
生產(chǎn)庫自動化MySQL5.6安裝部署詳細(xì)教程
自動化運(yùn)維是一個(gè)DBA應(yīng)該掌握的技術(shù),其中,自動化安裝數(shù)據(jù)庫是一項(xiàng)基本的技能,這篇文章主要介紹了生產(chǎn)庫自動化MySQL5.6安裝部署詳細(xì)教程,需要的朋友可以參考下2016-09-09

