欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Qt中操作MySQL數(shù)據(jù)庫的實(shí)戰(zhàn)指南

 更新時間:2023年04月03日 14:36:04   作者:可樂嘍  
QT連接Mysql數(shù)據(jù)庫的步驟相對繁瑣,但是也是一個不錯的學(xué)習(xí)經(jīng)歷,下面這篇文章主要給大家介紹了關(guān)于在Qt中操作MySQL數(shù)據(jù)庫的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

一、安裝驅(qū)動

(1)安裝

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

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

(2)驗(yàn)證驅(qū)動是否安裝成功 

復(fù)制成功之后來測試一下驅(qū)動程序是否安裝成功,新建一個文件,選擇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)行,如果不彈出警告窗口則說明安裝成功,否則就是失敗了。

//添加一個數(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");    //這個就是安裝MySQL時設(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)建一個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)建一個QSqlQuery對象
    query.exec(sql);    //執(zhí)行mysql語句

(2)多語句執(zhí)行

在sql中,每條語句用分號隔開就可以同時執(zhí)行多條語句了。下面同時對表格進(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)建一個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)建一個id列表
    idList << 15<<16<<17;
    query.addBindValue(idList); //完成第一個?的綁定
    QVariantList nameList;
    nameList << "ddd"<<"eee"<<"jjj";
    query.addBindValue(nameList);   //完成第二個?的綁定
    QVariantList ageList;
    ageList << 25<<24<<23;
    query.addBindValue(ageList);    //完成第三個?的綁定
    QVariantList mathList;
    mathList << 90<<89<<90;
    query.addBindValue(mathList);   //完成第四個?的綁定
    //執(zhí)行批處理
    query.execBatch();

方式二:bindValue()

直接用自定義的名稱來完成綁定,這時綁定順序可以自己決定。

	QSqlQuery query;
    query.prepare("insert into student (id,name,age,math) values (:id,:name,:age,:math)");  //:id之類的名字時自定義的 自己方便就好
    //添加綁定數(shù)據(jù)
    QVariantList idList;    //創(chuàng)建一個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)文章

最新評論