公司做网站有什么用,百度人工优化,深圳市手机网站建设报价,泡泡h5网页制作一、安装驱动
#xff08;1#xff09;安装
在Qt中操作MySQL数据库首先要安装mysql的驱动文件#xff0c;将MySQL下的libmusql.dll文件复制到Qt的安装路径下的bin文件夹下即可。 本文福利#xff0c;莬费领取Qt开发学习资料包、技术视频#xff0c;内容包括#xff08;…一、安装驱动
1安装
在Qt中操作MySQL数据库首先要安装mysql的驱动文件将MySQL下的libmusql.dll文件复制到Qt的安装路径下的bin文件夹下即可。 本文福利莬费领取Qt开发学习资料包、技术视频内容包括Qt实战项目视频教程代码C语言基础C设计模式Qt编程入门QT信号与槽机制QT界面开发-图像绘制QT网络QT数据库编程QT项目实战QSSOpenCVQuick模块面试题等等↓↓↓↓↓↓见下面↓↓文章底部点击莬费领取↓↓ 直接将libmysql.dll文件粘贴到此文件夹中。 2验证驱动是否安装成功
复制成功之后来测试一下驱动程序是否安装成功新建一个文件选择Qt设计师界面类后面的操作都保持默认即可。 在新生成的.cpp文件中引入以下库
#include QSqlDatabase
#include QDebug
#include QMessageBox
#include QSqlError
#include QString
#include QSqlQuery
#include QVariantList
在构造函数中插入以下代码然后点击运行如果不弹出警告窗口则说明安装成功否则就是失败了。
//添加一个数据库QSqlDatabase dbQSqlDatabase::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,kaw,20,97); //书写想要执行的语句QSqlQuery query; //创建一个QSqlQuery对象query.exec(sql); //执行mysql语句
2多语句执行
在sql中每条语句用分号隔开就可以同时执行多条语句了。下面同时对表格进行增加、删除和更新操作。
QString sql insert into student (id,name,age,math) values (13,kaw,20,97);delete from student where id2;update student set namesdd,math100 where id10;;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 151617;query.addBindValue(idList); //完成第一个?的绑定QVariantList nameList;nameList dddeeejjj;query.addBindValue(nameList); //完成第二个?的绑定QVariantList ageList;ageList 252423;query.addBindValue(ageList); //完成第三个?的绑定QVariantList mathList;mathList 908990;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 181920;query.bindValue(:id,idList); //完成:id的绑定QVariantList nameList;nameList dddeeejjj;query.bindValue(:name,nameList); //完成:name的绑定QVariantList ageList;ageList 252423;query.bindValue(:age,ageList); //完成:age的绑定QVariantList mathList;mathList 908990;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开发学习资料包、技术视频内容包括Qt实战项目视频教程代码C语言基础C设计模式Qt编程入门QT信号与槽机制QT界面开发-图像绘制QT网络QT数据库编程QT项目实战QSSOpenCVQuick模块面试题等等↓↓↓↓↓↓见下面↓↓文章底部点击莬费领取↓↓