在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文件中引入以下库

复制代码
#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。为避免出错,请按照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开发学习资料包、技术视频,内容包括(Qt实战项目视频教程+代码,C++语言基础,C++设计模式,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击** 莬**费领取↓↓****

相关推荐
虾球xz4 分钟前
游戏引擎学习第266天:添加顶部时钟概览视图。
数据库·c++·学习·游戏引擎
老友@1 小时前
MySQL 与 Elasticsearch 数据一致性方案
数据库·mysql·elasticsearch·搜索引擎·同步·数据一致性
bbqz0071 小时前
Qml Console
c++·qt·qml
chunfeng—1 小时前
Redis相关命令详解与原理(一)
数据库·redis·缓存
老友@1 小时前
MySQL + Elasticsearch:为什么要使用ES,使用场景与架构设计详解
数据库·mysql·elasticsearch·搜索引擎·性能优化·系统架构
檀越剑指大厂1 小时前
【SQL系列】多表关联更新
数据库·sql
♡喜欢做梦2 小时前
【MySQL】联合查询
数据库·mysql
老华带你飞4 小时前
音乐网站|基于SprinBoot+vue的音乐网站(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·音乐网站
gadiaola8 小时前
MySQL从入门到精通(三):MySQL数据类型、SQL语言—DDL
数据库·sql·mysql·database
muxue17810 小时前
关于almalinux分区配置:
linux·运维·数据库