Qt + MySQL(简单的增删改查)

Qt编译MySql插件教程

QSqlDatabase

静态函数

1.drivers(),得到可以使用的数据库驱动名字的集合

[static] QStringList QSqlDatabase::drivers();

2.addDatabase(),添加一个数据库实例

[static] QSqlDatabase QSqlDatabase::addDatabase(const QString &type, const QString &connectionName = QLatin1String( defaultConnection ));

该函数的有两个参数分别是:

type: 指定要连接什么样的数据库,就是数据库驱动对应的驱动名
connectionName:数据库连接名,默认叫: defaultConnection,我们可以在应用程序中添加多个数据库连接(也就是多个实例),每个连接都对应一个唯一的名字。
函数的返回值就是得到的数据库实例对象。

3.database(),通过数据库连接名得到数据库实例对象

[static] QSqlDatabase QSqlDatabase::database(const QString &connectionName = QLatin1String( defaultConnection ), bool open = true);

该函数的有两个参数分别是:

connectionName: 通过addDatabase()函数的第二个参数指定的连接名
open: 实例的状态

  • true: 得到的实例设置为打开状态
  • false: 得到的实例设置为关闭状态

4.判断连接名对应的连接是否已经存在了,给函数参数指定数据库连接名函数就可以返回连接对应的状态了:true(打开) 或者 false(关闭)。

[static] bool QSqlDatabase::contains(const QString &connectionName = QLatin1String( defaultConnection ));

普通成员函数

// 1.设置数据库名
void QSqlDatabase::setDatabaseName(const QString &name);
// 2.设置数据库服务器主机名(一般指定服务器IP地址即可)
void QSqlDatabase::setHostName(const QString &host);
// 3.设置数据库服务器绑定的端口
void QSqlDatabase::setPort(int port);// 如果数据库服务器绑定的是默认端口,可以省略设置端口的操作。
// 4.设置连接的数据库中某个用户的用户名
void QSqlDatabase::setUserName(const QString &name);
// 5.设置连接的数据库中某个用户对应的密码
void QSqlDatabase::setPassword(const QString &password);// 6.连接数据库(必须要先设置连接信息,然后再连接数据库)
bool QSqlDatabase::open();// 数据库连接成功返回true,连接失败返回false。
// 7.判断数据库是否打开了,返回值和open()函数相同。
bool QSqlDatabase::isOpen() const;
// 8.关闭数据库连接
void QSqlDatabase::close();
// 9.返回有关数据库上发生的最后一个错误的信息。
QSqlError QSqlDatabase::lastError() const;
QString QSqlError::text() const;
// 该函数返回的是一个QSqlError对象,调用QSqlError类提供的text()方法就可以得到最后一个错误对应的信息描述了。// 事务操作
// 10.创建一个事务
bool QSqlDatabase::transaction();
// 11.提交事务
bool QSqlDatabase::commit();
// 12.事务回滚
bool QSqlDatabase::rollback();

QSqlQuery

QSqlQuery 封装了从 QSqlDatabase上执行的SQL查询中创建、导航和检索数据所涉及的功能。既可以执行 SELECTINSERTUPDATEDELETE等DML(数据操作语言)语句,也可以执行CREATE TABLE等DDL(数据定义语言)语句。

成员函数

1.构造函数

QSqlQuery::QSqlQuery(const QString &query = QString(), QSqlDatabase db = QSqlDatabase());

参数说明(这两个参数都有默认值,因此可以根据实际需求进行指定):
query:要执行的SQL语句,指定无参 exec() 执行的 SQL 语句
db:数据库实例对象,如果没有指定db,或者是无效的,则使用应用程序的默认数据库。

2.执行一个SQL语句

bool QSqlQuery::exec();    // 没有参数,执行的SQL语句是在构造函数中指定的
bool QSqlQuery::exec(const QString &query);   // 有参数,参数对应的字符串就是要执行的SQL语句

3.检索查询得到的结果集中的下一条记录(如果可用),并将查询定位到检索到的记录上。

bool QSqlQuery::next();

该函数检索结果集中的每一条记录的规则如下:

  • 如果当前位于结果集第一个记录之前,例如,在执行查询之后,将尝试检索第一个记录。
  • 如果当前位于结果集最后一条记录之后,结果集已经检索完毕并返回false。
  • 如果结果位于结果集中间的某个位置,则尝试检索下一个记录。

函数调用之后,如果检索到有效记录返回true,否则返回false。

4.获取当前记录中字段的值

QVariant QSqlQuery::value(int index) const;  // 通过字段的索引得到当前字段的值,编号从0开始。
QVariant QSqlQuery::value(const QString &name) const; // 通过字段的名字得到当前字段的值。

由于数据库表中的字段可以有多种数据类型,因此将这多种类型通过 QVariant 类进行了包装从而实现了整齐划一。我们可以通过调用 QVariant 类的API函数得到其内部实际类型的数据。

ui界面
在这里插入图片描述
使用 QSqlQuery 进行查询时,字符类型的参数的占位符加引号 QString("select *from student where num = '%1'").arg(searchname);;但是对于数值类型的参数的占位符,QString("select *from student where num = '%1'").arg(searchnumer);QString("select *from student where num = %1").arg(searchnumer); ,加不加引号都可以正常查询

QSqlQuery简单使用

代码:

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QSqlDatabase>
#include <QMessageBox>
#include <QSqlDatabase>
#include <QSqlError>
#include <QDebug>MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);setWindowTitle("SQL");//设置窗口的标题connect(ui->pushButtonInsert, &QPushButton::clicked, this, &MainWindow::pInsert_clicked);connect(ui->pushButtonDelete, &QPushButton::clicked, this, &MainWindow::pDelete_clicked);connect(ui->pushButtonModify, &QPushButton::clicked, this, &MainWindow::pModify_clicked);connect(ui->pushButtonSelect, &QPushButton::clicked, this, &MainWindow::pSelect_clicked);connect(ui->pushButtonSelectAll, &QPushButton::clicked, this, &MainWindow::pSelectAll_clicked);ui->textEdit->setText("右侧栏操作介绍:\n""1.插入:输入新学生的姓名,学号,分数\n""2.删除:输入要删除学生的姓名\n""3.修改:输入学生姓名,对其学号和分数进行修改\n""4.指定信息优先按姓名查询,其次按学号\n""5.查询所有学生信息");QStringList list = QSqlDatabase::drivers();qDebug() << list;QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");db.setHostName("127.0.0.1"); // 本地连接db.setPort(3306);       // 如果使用的是默认端口可以不设置db.setUserName("");	// 数据库用户名db.setPassword(""); // 数据库密码db.setDatabaseName("student"); // 数据库名字if(db.open()){QMessageBox::information(this, "打开数据库", "数据库打开成功, 可以读写数据了......");}else{QString msg = "数据库打开失败: " + db.lastError().text();QMessageBox::information(this, "打开数据库", msg);}pquery = new QSqlQuery(db);QString str = "create table IF NOT EXISTS student(num int, name varchar(32), score double);";pquery->exec(str); // 建表
}MainWindow::~MainWindow()
{delete ui;
}void MainWindow::pInsert_clicked()
{if(ui->lineEditName->text().isEmpty() ||ui->lineEditNumber->text().isEmpty() ||ui->lineEditScore->text().isEmpty()) {QMessageBox::information(this, "Insert Error", "要插入的学生信息必须完整");return;}QString namestr = ui->lineEditName->text();int num = ui->lineEditNumber->text().toInt();double score = ui->lineEditScore->text().toDouble();QString str = QString("insert into student(num, name, score) values('%1', '%2', '%3')").arg(num).arg(namestr).arg(score);pquery->exec(str);ui->textEdit->append("插入成功\n");
}void MainWindow::pDelete_clicked()
{if(ui->lineEditName->text().isEmpty()) {QMessageBox::information(this, "Delete Error", "必须给出要删除学生的姓名");return;}QString name = ui->lineEditName->text();//从行编辑框中获取需要删除的人名QString str = QString("select * from student where name = '%1'").arg(name);pquery->exec(str);if(pquery->size() <= 0) {QMessageBox::information(this, "Delete Error", "要删除的学生不存在,请检查输入的姓名是否正确");return;}str =  QString("delete from student where name = '%1'").arg(name);pquery->exec(str);ui->textEdit->append(QString("删除姓名为%1的同学成功\n").arg(name));
}void MainWindow::pModify_clicked()
{if(ui->lineEditName->text().isEmpty() ||ui->lineEditNumber->text().isEmpty() ||ui->lineEditScore->text().isEmpty()) {QMessageBox::information(this, "Insert Error", "要修改的学生信息必须完整");return;}QString updatename = ui->lineEditName->text();QString temp = QString("select * from student where name = '%1'").arg(updatename);pquery->exec(temp);if(pquery) {if(pquery->size() <= 0) {QMessageBox::information(this, "Insert Error", "要修改的学生不存在,请查看输入的姓名是否正确");return;}}int number = ui->lineEditNumber->text().toInt();double score = ui->lineEditScore->text().toDouble();temp = QString("update student set num = '%1' , score = '%2' where name = '%3'").arg(number).arg(score).arg(updatename);pquery->exec(temp);//执行修改信息的操作ui->textEdit->append("修改成功\n");
}void MainWindow::pSelect_clicked()
{if(ui->lineEditName->text().isEmpty() && ui->lineEditNumber->text().isEmpty()) {QMessageBox::information(this, "Select Error", "必须指定查询的姓名或者学号");return;}QString searchname = ui->lineEditName->text();int searchnumer = ui->lineEditNumber->text().toInt();QString str;if(!ui->lineEditName->text().isEmpty()) {str = QString("select *from student where name = '%1'").arg(searchname);pquery->exec(str);if(pquery->size() <= 0) {QMessageBox::information(this, "Select Error", "要查询的学生不存在,请查看输入的姓名是否正确");return;}ui->textEdit->append(QString("查询姓名为%1的同学成功").arg(searchname));}else if(!ui->lineEditNumber->text().isEmpty()) {str = QString("select *from student where num = '%1'").arg(searchnumer);pquery->exec(str);if(pquery->size() <= 0) {QMessageBox::information(this, "Select Error", "要查询的学生不存在,请查看输入的学号是否正确");return;}ui->textEdit->append(QString("查询学号为%1的同学成功").arg(searchnumer));}pquery->exec(str);QString name;int number = 0;double score;while (pquery->next()){number = pquery->value(0).toInt();name = pquery->value(1).toString();score =  pquery->value(2).toDouble();str = "学号: " + QString::number(number) + " " +"姓名: " + name + " " +"分数: " + QString::number(score);ui->textEdit->append(str);}ui->textEdit->append("\n");
}void MainWindow::pSelectAll_clicked()
{QString str = QString("select *from student");pquery->exec(str);if(pquery->size() <= 0) {QMessageBox::information(this, "Select Error", "目前student里没有信息");}ui->textEdit->append("查询所有成员成功");QString name;int number = 0;double score;while (pquery->next()){number = pquery->value(0).toInt();name = pquery->value(1).toString();score =  pquery->value(2).toDouble();str = "学号: " + QString::number(number) + " " +"姓名: " + name + " " +"分数: " + QString::number(score);ui->textEdit->append(str);}ui->textEdit->append("\n");
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/201614.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ROS小练习——话题发布

目录 一、话题与消息获取 1、话题 2、消息 二、代码编写 1、C 2、python 三、编译运行 一、话题与消息获取 打开小乌龟案例 1、话题 rqt_graph rostopic list 2、消息 获取消息类型: rostopic type /turtle1/cmd_vel 获取消息格式: rosmsg info geometry_msgs/Twi…

PieCloudDB Database 自研全新向量化执行器,带来性能的数量级提升

数据分析和应用的重要性日益增长&#xff0c;对于数据平台和数据计算系统来说&#xff0c;极致的性能是关键需求之一。为实现更高效的数据并行计算&#xff0c;一款优秀的执行器需要能够充分利用硬件资源&#xff0c;如 CPU 的并行计算能力和 SIMD 指令集。此外&#xff0c;优化…

【用unity实现100个游戏之18】从零开始制作一个类CSGO/CS2、CF第一人称FPS射击游戏——基础篇1(附项目源码)

文章目录 本节最终效果前言搭建环境玩家移动控制摄像机跟随和视角人物奔跑实现跳跃斜坡顿挫感人物卡墙问题源码完结 本节最终效果 前言 生存和射击游戏一直是我的最爱&#xff0c;说起3D最普遍的应该就是射击系统了&#xff0c;你可以在任何情况下加入射击功能&#xff0c;所以…

insert操作引起的row lock测验(Row Locking on Insert)

文章目录 一、测验二、结论 记录insert 引发的row lock等待的测验 一、测验 1.创建主从表 create table t1 (id1 int primary key ); create table t2 (id1 int references t1 (id1) );insert into t1 values (1); insert into t2 values (1); commit2.从session 1删除子表 s…

软件工程之架构设计

从公众号转载&#xff0c;关注微信公众号掌握更多技术动态 --------------------------------------------------------------- 一、架构设计的目的 1.什么是复杂的软件项目 复杂的软件项目通常有两个特点&#xff1a; 需求不确定 技术复杂 技术的复杂性主要体现在四个方面…

Ubuntu防止休眠和挂起(笔记)

目录 1 动机2 禁用休眠3 解除休眠 1 动机 我要将 饿啊人制作成 noah-mp 的区域运行强迫&#xff0c;但是跑的慢&#xff0c;一晚上两天。后来发现是因为电脑自动 supend 了。Ubuntu 在电源那里最多只能设置 2 小时的防止休眠&#xff0c;2小时候又自动休眠&#xff0c;严重影响…

Python中的global关键字

Python中的global关键字 Python是一种简单而强大的编程语言&#xff0c;提供了许多功能和语法来帮助开发人员编写高效的代码。其中一个常用的功能是使用global关键字来在函数内部访问和修改全局变量。 在本文中&#xff0c;我们将深入探讨Python中global关键字的用法&#xf…

服务器端口该怎么维护_Maizyun

服务器端口该怎么维护 在互联网环境中&#xff0c;服务器端口是网络通信的重要通道。每个端口对应着特定的服务或应用程序。然而&#xff0c;不正确的端口配置或缺乏适当的维护可能导致安全漏洞和性能问题。因此&#xff0c;维护服务器的端口安全和稳定性至关重要。本文将探讨…

导入JSON到xmind

写在前面 这只是一个思路&#xff0c;解决大量树状数据&#xff0c;创建xmind低效问题。 函数可以根据你的实际情况优化 1. 转换json格式 function formatToXimd(atd, str) {if (atd) {for (let index 0; index < atd.length; index) {console.log(str - atd[index].…

RK3288升级WebView版本,替换webview app

升级高版本的WebView Apk&#xff1b;客户端播放网页&#xff0c;显示不正常&#xff1b;安装高版本的谷歌浏览器手动打开网页&#xff0c;显示正常&#xff1b;Android5.1开始&#xff0c;WebView具体实现从框架层剥离出来&#xff0c;通过一个包名来控制加载真正的WebView实现…

论在武汉考一个安全员B证能有多难?谁曾想

论在武汉考一个安全员B证能有多难&#xff1f;谁曾想 在武汉考一个安全员B证的考试难度&#xff0c;硬考&#xff08;自己练习系统题库备考&#xff09;还是有一定难度的。毕竟考试范围比较宽泛&#xff0c;里边涉及日常工作内容、法规知识、建筑管理知识等等。即使你考过了二…

CVE-2023-3710:Honeywell Products远程命令执行漏洞复现 [附POC]

文章目录 Honeywell Products远程命令执行(CVE-2023-3710)漏洞复现 [附POC]0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现0x06 修复建议Honeywell Products远程命令执行(CVE-2023-3710)漏洞复现 [附POC] 0x01 前言 免责声明:…

AOP记录操作日志

创建数据库表 -- 操作日志 create table operate_log (id int unsigned primary key auto_increment commentid,operate_user int unsigned comment 操作人员Id,operate_time datetime comment 操作时间,class_name varchar(100)comment 操作类,method_name varchar(100)comme…

C语言——I /深入理解指针(五)

一、sizeof 和 strlen 的对比 1、sizeof sizeof是操作符&#xff0c;计算变量所占内存内存空间⼤⼩的&#xff0c;单位是字节&#xff0c;如果操作数是类型的话&#xff0c;计算的是使⽤类型创建的变量所占内存空间的⼤⼩。 sizeof 只关注占⽤内存空间的⼤⼩&#xff0c;不在…

鸿蒙4.0开发笔记之ArkTS语法基础的UI描述、基础组件的使用与如何查看组件是否有参数(八)

文章目录 一、声明式UI描述1、无/有参数组件2、如何查看组件是否有参数 二、Image组件的使用三、组件的属性设置四、补充1、使用组件的成员函数配置组件的事件方法2、配置子组件3、多组件嵌套 一、声明式UI描述 在HarmonyOS的ArkTS语法中&#xff0c;万物皆组件。ArkTS以声明方…

【Verilog】 FPGA程序设计---Verilog基础知识

目录 Verilog 和 VHDL 区别 Verilog 和 C 的区别 Verilog 基础知识 1 Verilog 的逻辑值 2 Verilog 的标识符 3 Verilog 的数字进制格式 4 Verilog 的数据类型 1) 寄存器类型 2) 线网类型 3) 参数类型 5 Verilog 的运算符 1) 算术运算符 2) 关系运算…

数据结构之选择排序

目录 直接选择排序 选择排序的时间复杂度 堆排序 向上调整算法 向下调整算法 向上调整算法建立堆 向下调整算法建立堆 堆排序整体代码 堆排序的时间复杂度 直接选择排序 在之前讲插入排序时&#xff0c;我们讲了这样的一个应用场景&#xff0c;我们在斗地主摸牌时&…

Lean语言学习笔记

Lean是什么&#xff1f; Lean 是一门可作为交互式定理证明工具的函数式编程语言。 创建Lean项目 可以使用 lake 来创建一个新的 Lean 项目&#xff1a; mkdir lean-playground && cd lean-playground lake init foo之后会得到下面的目录结构&#xff1a; ├── F…

国产智能运维操作系统新选择-浪潮KeyarchOS

1.背景 在CentOS停更&#xff0c;国有企业纷纷摒弃原有的开发与运维工具&#xff0c;全面拥抱国产。我司也顺应号召&#xff0c;更换原有CentOS系统。 在新系统选型上&#xff0c;我司有以下要求&#xff1a; 国产、快速更新迭代、社区活跃&#xff1b;拥有一定知名度&#x…

Kotlin 中的 var 和 val:选择正确的变量声明

在 Kotlin 编程语言中&#xff0c;var 和 val 是两个基本的关键字&#xff0c;用于变量声明。 它们的正确使用对于编写可维护和高效的代码至关重要。 一、对比分析&#xff1a; var &#xff1a;用于声明可变变量。使用 var 声明的变量可以在初始化后被重新赋值。val &#…