在Qt中怎麼操作MySQL資料庫

PHPz
發布: 2023-06-03 08:52:31
轉載
2044 人瀏覽過

    一、安裝驅動程式

    (1)安裝

    在Qt中操作MySQL資料庫首先要安裝mysql的驅動文件,將MySQL下的libmusql.dll檔案複製到Qt的安裝路徑下的bin資料夾下即可。

    在Qt中怎麼操作MySQL資料庫

    直接將libmysql.dll檔案貼到此資料夾中。

    在Qt中怎麼操作MySQL資料庫

    (2)驗證驅動程式是否安裝成功 

    複製成功之後來測試驅動程式是否安裝成功,新建一個文件,選擇Qt設計師介面類,後面的操作都保持預設即可。

    在Qt中怎麼操作MySQL資料庫

    在新生成的.cpp檔案中引入以下程式庫

    #include <QSqlDatabase>
    #include <QDebug>
    #include <QMessageBox>  
    #include <QSqlError>    
    #include <QString>
    #include <QSqlQuery>
    #include <QVariantList>
    登入後複製

    在建構函式中插入以下程式碼,然後點擊運行,如果不彈出警告窗口則表示安裝成功,否則就是失敗了。

    //添加一个数据库
        QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");    //括号内要写出数据库的类型
        //设置数据库
        db.setHostName("127.0.0.1"); //设置数据库的主机ip
        //设置数据库的用户名
        db.setUserName("root");
        //设置数据库的密码
        db.setPassword("123456");    //这个就是安装MySQL时设置的密码
        //设置数据库的名字
        db.setDatabaseName("aaa2");
        //打开数据库(已经安装过mysql驱动了)
        if(db.open()==false){
            QMessageBox::warning(this,"waring",db.lastError().text());
        }
    登入後複製

    二、使用MySQL資料庫

    (1)單一語句執行

    先建立一個QString物件sql,將要執行的語句寫在 sql中,然後建立QSqlQuery類的物件query,呼叫其exec()函數執行sql中的程式碼。

        QString sql = "insert into student (id,name,age,math) values (1,&#39;kaw&#39;,20,97)";	//书写想要执行的语句
        QSqlQuery query;	//创建一个QSqlQuery对象
        query.exec(sql);    //执行mysql语句
    登入後複製

    (2)多語句執行

    在sql中,每個語句用分號隔開就可以同時執行多條語句了。下面同時對表格進行增加、刪除和更新操作。

        QString sql = "insert into student (id,name,age,math) values (13,&#39;kaw&#39;,20,97);delete from student where id=2;update student set name=&#39;sdd&#39;,math=100 where id=10;";
        QSqlQuery query;	//创建一个QSqlQuery对象
        query.exec(sql);    //执行mysql语句
    登入後複製

    (3)批次操作

    方式一:addBindValue()

    在query.prepare()中輸入自己想要執行的語句,其中待輸入的值用“?”代替,在這裡“?”就是通配符。在後面加入自己想要設定的值時,可以使用idList、nameList、ageList和mathList。為避免出錯,請依照id、name、age、math的順序來使用addBindValue()進行值的綁定。

        QSqlQuery query;
        query.prepare("insert into student (id,name,age,math) values (?,?,?,?)");	//书写语句模型
        //添加绑定数据
        QVariantList idList;    //创建一个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);   //完成第四个?的绑定
        //执行批处理
        query.execBatch();
    登入後複製

    方式二:bindValue()

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

    	QSqlQuery query;
        query.prepare("insert into student (id,name,age,math) values (:id,:name,:age,:math)");  //:id之类的名字时自定义的 自己方便就好
        //添加绑定数据
        QVariantList idList;    //创建一个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的绑定
        //执行批处理
        query.execBatch();
    登入後複製

    (4)查詢

    要查詢的表為:

    在Qt中怎麼操作MySQL資料庫

    value後面的值可以是索引,也可以是列名。取出後需要將其轉為對應的資料類型。

    	//查询操作
        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();   
        }
    登入後複製

    查詢結果:

    在Qt中怎麼操作MySQL資料庫

    #

    以上是在Qt中怎麼操作MySQL資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    相關標籤:
    來源:yisu.com
    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
    熱門教學
    更多>
    最新下載
    更多>
    網站特效
    網站源碼
    網站素材
    前端模板
    關於我們 免責聲明 Sitemap
    PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!