• 在Qt中怎么操作MySQL数据库


    一、安装驱动

    (1)安装

    在Qt中操作MySQL数据库首先要安装mysql的驱动文件,将MySQL下的libmusql.dll文件复制到Qt的安装路径下的bin文件夹下即可。

    本文福利,费领取Qt开发学习资料包、技术视频,内容包括(Qt实战项目视频教程+代码,C++语言基础,C++设计模式,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

    直接将libmysql.dll文件粘贴到此文件夹中。

    (2)验证驱动是否安装成功

    复制成功之后来测试一下驱动程序是否安装成功,新建一个文件,选择Qt设计师界面类,后面的操作都保持默认即可。

    在新生成的.cpp文件中引入以下库

    1. #include
    2. #include
    3. #include
    4. #include
    5. #include
    6. #include
    7. #include

    在构造函数中插入以下代码,然后点击运行,如果不弹出警告窗口则说明安装成功,否则就是失败了。

    1. //添加一个数据库
    2. QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL"); //括号内要写出数据库的类型
    3. //设置数据库
    4. db.setHostName("127.0.0.1"); //设置数据库的主机ip
    5. //设置数据库的用户名
    6. db.setUserName("root");
    7. //设置数据库的密码
    8. db.setPassword("123456"); //这个就是安装MySQL时设置的密码
    9. //设置数据库的名字
    10. db.setDatabaseName("aaa2");
    11. //打开数据库(已经安装过mysql驱动了)
    12. if(db.open()==false){
    13. QMessageBox::warning(this,"waring",db.lastError().text());
    14. }

    二、使用MySQL数据库

    (1)单语句执行

    首先创建一个QString对象sql,将要执行的语句写在 sql中,然后创建QSqlQuery类的对象query,调用其exec()函数执行sql中的代码。

    1. QString sql = "insert into student (id,name,age,math) values (1,'kaw',20,97)"; //书写想要执行的语句
    2. QSqlQuery query; //创建一个QSqlQuery对象
    3. query.exec(sql); //执行mysql语句

    (2)多语句执行

    在sql中,每条语句用分号隔开就可以同时执行多条语句了。下面同时对表格进行增加、删除和更新操作。

    1. 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;";
    2. QSqlQuery query; //创建一个QSqlQuery对象
    3. query.exec(sql); //执行mysql语句

    (3)批处理操作

    方式一:addBindValue()

    在query.prepare()中输入自己想要执行的语句,其中待输入的值用“?”代替,在这里“?”就是通配符。在后面添加自己想要设置的值时,可以使用idList、nameList、ageList和mathList。为避免出错,请按照id、name、age、math的顺序来使用addBindValue()进行值的绑定。

    1. QSqlQuery query;
    2. query.prepare("insert into student (id,name,age,math) values (?,?,?,?)"); //书写语句模型
    3. //添加绑定数据
    4. QVariantList idList; //创建一个id列表
    5. idList << 15<<16<<17;
    6. query.addBindValue(idList); //完成第一个?的绑定
    7. QVariantList nameList;
    8. nameList << "ddd"<<"eee"<<"jjj";
    9. query.addBindValue(nameList); //完成第二个?的绑定
    10. QVariantList ageList;
    11. ageList << 25<<24<<23;
    12. query.addBindValue(ageList); //完成第三个?的绑定
    13. QVariantList mathList;
    14. mathList << 90<<89<<90;
    15. query.addBindValue(mathList); //完成第四个?的绑定
    16. //执行批处理
    17. query.execBatch();

    方式二:bindValue()

    直接用自定义的名称来完成绑定,这时绑定顺序可以自己决定。

    1. QSqlQuery query;
    2. query.prepare("insert into student (id,name,age,math) values (:id,:name,:age,:math)"); //:id之类的名字时自定义的 自己方便就好
    3. //添加绑定数据
    4. QVariantList idList; //创建一个id列表
    5. idList << 18<<19<<20;
    6. query.bindValue(":id",idList); //完成:id的绑定
    7. QVariantList nameList;
    8. nameList << "ddd"<<"eee"<<"jjj";
    9. query.bindValue(":name",nameList); //完成:name的绑定
    10. QVariantList ageList;
    11. ageList << 25<<24<<23;
    12. query.bindValue(":age",ageList); //完成:age的绑定
    13. QVariantList mathList;
    14. mathList << 90<<89<<90;
    15. query.bindValue(":math",mathList); //完成:math的绑定
    16. //执行批处理
    17. query.execBatch();

    (4)查询

    要查询的表为:

    value后的值可以是索引,也可以是列名。取出后需要将其转为对应的数据类型。

    1. //查询操作
    2. QSqlQuery query;
    3. query.exec("select * from student");
    4. while(query.next()){
    5. qDebug()<<query.value(0).toInt()
    6. <<query.value("name").toString().toUtf8().data()
    7. <<query.value(2).toInt()
    8. <<query.value(3).toInt();
    9. }

    查询结果:

    本文福利,费领取Qt开发学习资料包、技术视频,内容包括(Qt实战项目视频教程+代码,C++语言基础,C++设计模式,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

  • 相关阅读:
    自然语言处理(NLP)技术介绍
    flink 事件处理 CEP
    python Web自动化之Selenium的基本使用
    云计算学习8——OpenStack高级运维企业实战竞赛题目
    计算机网络
    Dubbo消费端调用全过程实现分析-负载均衡与集群容错
    ffmpeg批量转码
    MyBatis-plus框架使用
    Flink状态管理与恢复
    C++函数在重载时如何判断函数签名(function signature)是否相同
  • 原文地址:https://blog.csdn.net/m0_73443478/article/details/133960500