溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)

發(fā)布時(shí)間:2023-04-03 15:46:52 來(lái)源:億速云 閱讀:144 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

    一、安裝驅(qū)動(dòng)

    (1)安裝

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

    在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)

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

    在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)

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

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

    在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)

    在新生成的.cpp文件中引入以下庫(kù)

    #include <QSqlDatabase>
    #include <QDebug>
    #include <QMessageBox>  
    #include <QSqlError>    
    #include <QString>
    #include <QSqlQuery>
    #include <QVariantList>

    在構(gòu)造函數(shù)中插入以下代碼,然后點(diǎn)擊運(yùn)行,如果不彈出警告窗口則說(shuō)明安裝成功,否則就是失敗了。

    //添加一個(gè)數(shù)據(jù)庫(kù)
        QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");    //括號(hào)內(nèi)要寫出數(shù)據(jù)庫(kù)的類型
        //設(shè)置數(shù)據(jù)庫(kù)
        db.setHostName("127.0.0.1"); //設(shè)置數(shù)據(jù)庫(kù)的主機(jī)ip
        //設(shè)置數(shù)據(jù)庫(kù)的用戶名
        db.setUserName("root");
        //設(shè)置數(shù)據(jù)庫(kù)的密碼
        db.setPassword("123456");    //這個(gè)就是安裝MySQL時(shí)設(shè)置的密碼
        //設(shè)置數(shù)據(jù)庫(kù)的名字
        db.setDatabaseName("aaa2");
        //打開數(shù)據(jù)庫(kù)(已經(jīng)安裝過(guò)mysql驅(qū)動(dòng)了)
        if(db.open()==false){
            QMessageBox::warning(this,"waring",db.lastError().text());
        }

    二、使用MySQL數(shù)據(jù)庫(kù)

    (1)單語(yǔ)句執(zhí)行

    首先創(chuàng)建一個(gè)QString對(duì)象sql,將要執(zhí)行的語(yǔ)句寫在 sql中,然后創(chuàng)建QSqlQuery類的對(duì)象query,調(diào)用其exec()函數(shù)執(zhí)行sql中的代碼。

        QString sql = "insert into student (id,name,age,math) values (1,'kaw',20,97)";	//書寫想要執(zhí)行的語(yǔ)句
        QSqlQuery query;	//創(chuàng)建一個(gè)QSqlQuery對(duì)象
        query.exec(sql);    //執(zhí)行mysql語(yǔ)句

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

    在sql中,每條語(yǔ)句用分號(hào)隔開就可以同時(shí)執(zhí)行多條語(yǔ)句了。下面同時(shí)對(duì)表格進(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對(duì)象
        query.exec(sql);    //執(zhí)行mysql語(yǔ)句

    (3)批處理操作

    方式一:addBindValue()

    在query.prepare()中輸入自己想要執(zhí)行的語(yǔ)句,其中待輸入的值用“?”代替,在這里“?”就是通配符。后面再用idList、nameList、ageList和mathList添加自己想要設(shè)置的值。注意,addBindValue()綁定值的順序需要與id、name、age、math的順序一致。

        QSqlQuery query;
        query.prepare("insert into student (id,name,age,math) values (?,?,?,?)");	//書寫語(yǔ)句模型
        //添加綁定數(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()

    直接用自定義的名稱來(lái)完成綁定,這時(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)查詢

    要查詢的表為:

    在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)

    value后的值可以是索引,也可以是列名。取出后需要將其轉(zhuǎn)為對(duì)應(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é)果:

    在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)

    “在Qt中怎么操作MySQL數(shù)據(jù)庫(kù)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI