文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

在Qt中怎么操作MySQL数据库

2023-07-05 20:26

关注

本篇内容介绍了“在Qt中怎么操作MySQL数据库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、安装驱动

(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,'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 id=2;update student set name='sdd',math=100 where id=10;";    QSqlQuery query;//创建一个QSqlQuery对象    query.exec(sql);    //执行mysql语句

(3)批处理操作

方式一:addBindValue()

在query.prepare()中输入自己想要执行的语句,其中待输入的值用“?”代替,在这里“?”就是通配符。后面再用idList、nameList、ageList和mathList添加自己想要设置的值。注意,addBindValue()绑定值的顺序需要与id、name、age、math的顺序一致。

    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数据库”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯