在Qt中操作MySQL資料庫首先要安裝mysql的驅動文件,將MySQL下的libmusql.dll檔案複製到Qt的安裝路徑下的bin資料夾下即可。
直接將libmysql.dll檔案貼到此資料夾中。
複製成功之後來測試驅動程式是否安裝成功,新建一個文件,選擇Qt設計師介面類,後面的操作都保持預設即可。
在新生成的.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()); }
先建立一個QString物件sql,將要執行的語句寫在 sql中,然後建立QSqlQuery類的物件query,呼叫其exec()函數執行sql中的程式碼。
QString sql = "insert into student (id,name,age,math) values (1,'kaw',20,97)"; //书写想要执行的语句 QSqlQuery query; //创建一个QSqlQuery对象 query.exec(sql); //执行mysql语句
在sql中,每個語句用分號隔開就可以同時執行多條語句了。下面同時對表格進行增加、刪除和更新操作。
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; //创建一个QSqlQuery对象 query.exec(sql); //执行mysql语句
方式一: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)查詢
要查詢的表為:
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資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!