当前位置: 首页 > news >正文

QT基础篇(13)QT5数据库

1.数据库基本概念

数据库(Database)是指存储、管理和组织数据的集合。它是一个组织化的、可持久化的数据集合,用于支持数据的存储、检索、更新和管理。

数据库系统(Database System)是建立在计算机上的数据管理系统,由数据库、数据库管理系统(DBMS)和应用程序组成。它能够在计算机上创建、使用和维护数据库,提供数据的存储、检索和管理功能。

数据库管理系统(Database Management System,DBMS)是一种软件系统,用来管理数据库,提供对数据库的访问和操作接口,包括数据的存储、检索、更新、删除、查询等功能。常见的DBMS有MySQL、Oracle、SQL Server等。

数据库模型(Database Model)是数据库中数据的逻辑组织方式。常见的数据库模型有层次模型、网状模型、关系模型和面向对象模型。其中,关系模型是最常用的数据库模型,它将数据组织为表格(即关系),并使用关系代数和关系演算进行数据操作。

数据库管理系统通过SQL(Structured Query Language)语言来操作数据库。SQL是一种专门用来管理和操作关系型数据库的语言,它可以对数据库进行查询、更新、删除、插入等操作。

数据库的基本概念还包括数据模型、数据表、字段、记录、主键、外键、索引等。数据模型定义了数据库中数据的组织方式和关系;数据表是数据库中数据的逻辑结构,它由多个字段组成;字段是数据表中的一个属性,代表存储数据的最小单元;记录是数据表中的一行,代表一条具体的数据;主键是数据表中唯一标识记录的字段;外键是数据表中关联其他表的字段;索引是对数据库中某个字段或多个字段的值进行排序和存储,提高查询效率。

2.常用SQL语句
2.1 数据查询

常用的数据库查询SQL语句如下:

  1. SELECT: 用于查询数据库中的数据,可以选择要查询的字段、表格和条件。 例如:SELECT * FROM 表名; // 查询表中的所有字段和数据 SELECT 列名1, 列名2 FROM 表名; // 查询指定字段的数据 SELECT * FROM 表名 WHERE 条件; // 查询满足条件的数据

  2. INSERT INTO: 用于向数据库中插入新的数据。 例如:INSERT INTO 表名 (列名1, 列名2) VALUES (值1, 值2); // 插入指定字段的数据

  3. UPDATE: 用于更新数据库中的数据。 例如:UPDATE 表名 SET 列名1 = 新值1, 列名2 = 新值2 WHERE 条件; // 更新满足条件的数据

  4. DELETE: 用于删除数据库中的数据。 例如:DELETE FROM 表名 WHERE 条件; // 删除满足条件的数据

  5. WHERE: 用于筛选满足条件的数据。 例如:SELECT * FROM 表名 WHERE 列名 = 值; // 查询满足条件的数据

  6. ORDER BY: 用于对查询结果进行排序。 例如:SELECT * FROM 表名 ORDER BY 列名 ASC/DESC; // 按照指定列的升序/降序排序

  7. GROUP BY: 用于对查询结果进行分组。 例如:SELECT 列名1, 列名2 FROM 表名 GROUP BY 列名1; // 按照指定列进行分组

  8. JOIN: 用于将多个表格连接在一起进行查询。 例如:SELECT * FROM 表名1 JOIN 表名2 ON 表名1.列名 = 表名2.列名; // 连接两个表格查询数据

  9. HAVING: 用于在GROUP BY语句中对分组后的结果进行筛选。 例如:SELECT 列名1, COUNT(列名2) FROM 表名 GROUP BY 列名1 HAVING COUNT(列名2) > 值; // 筛选满足条件的分组结果

  10. DISTINCT: 用于去重查询结果。 例如:SELECT DISTINCT 列名 FROM 表名; // 查询指定字段的去重结果

以上是一些常用的数据库查询SQL语句,可以根据具体需求进行组合和扩展。

2.2 数据操作

常用的数据库数据操作SQL语句如下:

  1. INSERT INTO: 用于向数据库中插入新的数据。 例如:INSERT INTO 表名 (列名1, 列名2) VALUES (值1, 值2); // 插入指定字段的数据

  2. UPDATE: 用于更新数据库中的数据。 例如:UPDATE 表名 SET 列名1 = 新值1, 列名2 = 新值2 WHERE 条件; // 更新满足条件的数据

  3. DELETE: 用于删除数据库中的数据。 例如:DELETE FROM 表名 WHERE 条件; // 删除满足条件的数据

  4. TRUNCATE TABLE: 用于快速清空表中的数据,但不会回滚事务。 例如:TRUNCATE TABLE 表名; // 清空表中的数据

  5. CREATE TABLE: 用于创建新的数据库表。 例如:CREATE TABLE 表名 (列名1 数据类型, 列名2 数据类型, ...); // 创建表结构

  6. ALTER TABLE: 用于修改数据库表的结构。 例如:ALTER TABLE 表名 ADD 列名 数据类型; // 添加新的列 ALTER TABLE 表名 MODIFY 列名 数据类型; // 修改列的数据类型 ALTER TABLE 表名 DROP 列名; // 删除列

  7. CREATE INDEX: 用于创建索引,加快查询速度。 例如:CREATE INDEX 索引名 ON 表名 (列名); // 在指定列上创建索引

  8. DROP INDEX: 用于删除索引。 例如:DROP INDEX 索引名 ON 表名; // 删除指定表的索引

  9. CREATE VIEW: 用于创建视图,可以将数据库中的数据以虚拟表的形式展现。 例如:CREATE VIEW 视图名 AS SELECT 列名1, 列名2 FROM 表名; // 创建视图

  10. DROP VIEW: 用于删除视图。 例如:DROP VIEW 视图名; // 删除视图

以上是一些常用的数据库数据操作SQL语句,可以根据具体需求进行组合和扩展。

3. QT操作数据库
3.1 QT操作SQLite数据库

在QT5中操作SQLite数据库需要使用QT的数据库模块,需要引入以下头文件:

#include <QtSql>

首先,需要创建一个Qt数据库连接对象,代码如下:

QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("database.db");  // 数据库文件名,可以是绝对路径或相对路径if (!db.open()) {qDebug() << "Failed to open database!";return;
}

在数据库打开成功后,可以执行SQL语句进行数据操作。例如,创建一个表并插入数据:

QSqlQuery query;
query.exec("CREATE TABLE students (id INT PRIMARY KEY, name TEXT, age INT)");query.prepare("INSERT INTO students (id, name, age) VALUES (?, ?, ?)");
query.addBindValue(1);
query.addBindValue("John");
query.addBindValue(20);
query.exec();

注意,在执行SQL语句之前,需要创建一个QSqlQuery对象,用于执行和操作SQL语句。可以使用exec()函数执行SQL语句,或使用prepare()和bindValue()函数准备并执行参数化查询。

执行查询语句并获取结果:

if (query.exec("SELECT * FROM students")) {while (query.next()) {int id = query.value(0).toInt();QString name = query.value(1).toString();int age = query.value(2).toInt();qDebug() << "ID:" << id << "Name:" << name << "Age:" << age;}
}

以上代码演示了如何执行SELECT语句并获取查询结果。可以通过value()函数根据字段索引或字段名获取对应的值。

最后,关闭数据库连接:

db.close();

以上是简单的示例代码,通过QT的数据库模块可以实现更复杂的数据库操作,如更新、删除、事务处理等。详细的API文档可以参考QT官方文档。

3.2 QT操作主从视图及XML

在QT中,可以使用QTableView和QStandardItemModel来实现主从视图的操作。

首先,需要创建两个QTableView和对应的QStandardItemModel,一个是主视图,一个是从视图。代码如下:

QTableView* masterTableView = new QTableView;
QStandardItemModel* masterModel = new QStandardItemModel;QTableView* detailTableView = new QTableView;
QStandardItemModel* detailModel = new QStandardItemModel;

然后,将数据模型设置给相应的视图:

masterTableView->setModel(masterModel);
detailTableView->setModel(detailModel);

接下来,可以使用模型的方法来填充数据,例如:

QStandardItem* item1 = new QStandardItem("Item 1");
QStandardItem* item2 = new QStandardItem("Item 2");
QStandardItem* item3 = new QStandardItem("Item 3");masterModel->appendRow({ item1, item2, item3 });

在主视图中,可以监听当前选中的行,并根据选中的行来更新从视图的数据。代码如下:

connect(masterTableView->selectionModel(), &QItemSelectionModel::currentRowChanged, [=](const QModelIndex& current, const QModelIndex& previous) {if (current.isValid()) {int row = current.row();// 根据选中的行更新从视图的数据// ...}
});

以上代码演示了如何根据主视图的选中行来更新从视图的数据。你可以根据实际需求来获取选中行的数据,并更新从视图的模型。

关于XML的操作,QT提供了QXmlStreamReader和QXmlStreamWriter两个类来读取和写入XML数据。

例如,读取XML文件并解析数据:

QFile file("data.xml");
if (file.open(QIODevice::ReadOnly)) {QXmlStreamReader reader(&file);while (!reader.atEnd()) {if (reader.isStartElement()) {if (reader.name() == "name") {QString name = reader.readElementText();qDebug() << "Name:" << name;}}reader.readNext();}if (reader.hasError()) {qDebug() << "XML Error:" << reader.errorString();}file.close();
}

以上代码演示了如何逐行读取XML文件中的数据。你可以根据标签名来获取相应的数据。

写入XML数据的过程与读取类似,首先创建QXmlStreamWriter对象,并调用相应的方法来写入数据:

QFile file("data.xml");
if (file.open(QIODevice::WriteOnly)) {QXmlStreamWriter writer(&file);writer.setAutoFormatting(true);writer.writeStartDocument();writer.writeStartElement("root");writer.writeTextElement("name", "Name 1");writer.writeEndElement();writer.writeEndDocument();file.close();
}

以上代码演示了如何创建一个XML文件,并写入一些简单的数据。你可以根据实际需求来添加更多的标签和数据。

QT提供了丰富的API来处理主从视图和XML数据操作,上述代码只是简单示例,具体的使用方式可以参考QT官方文档。

相关文章:

QT基础篇(13)QT5数据库

1.数据库基本概念 数据库&#xff08;Database&#xff09;是指存储、管理和组织数据的集合。它是一个组织化的、可持久化的数据集合&#xff0c;用于支持数据的存储、检索、更新和管理。 数据库系统&#xff08;Database System&#xff09;是建立在计算机上的数据管理系统&…...

ctfshow信息收集(web1-web20)

目录 web1 web2 web3 web4 web5 web6 web7 web9 web10 web11 web14 web15 web16 web17 web18 web19 web20 web1 根据提示的孩子开发的时候注释没有被及时删除 web2 js原因无法查看源代码 第一种方法 在url前加入 view-source&#xff1a; 会显示页面源代…...

从零学习Hession RPC

为什么学习Hessian RPC&#xff1f; 存粹的RPC&#xff0c;只解决PRC的四个核心问题&#xff08;1.网络通信2.协议 3.序列化 4.代理&#xff09;Java写的HessianRPC落伍了&#xff0c;但是它的序列化方式还保存着&#xff0c;被Dubbo(Hessian Lite)使用。 被落伍&#xff0c;只…...

实施精细化管理的六大关键步骤

在当今高度竞争的市场环境中&#xff0c;企业若想脱颖而出&#xff0c;必须实现精细化管理。这不仅是为了提高效率&#xff0c;更是为了确保在复杂多变的市场中保持领先地位。通过以下六个关键步骤&#xff0c;企业可以构建一个强大的精细化管理体系&#xff0c;从而为未来的成…...

QT+C++环境调用python函数可以进入python环境和模块,但是调用功能函数错误

QTC环境使用Python.h调用python函数可以进入python环境和模块&#xff0c;但是调用功能函数错误 背景&#xff1a; 定义的python函数使用了其他库封装好的函数&#xff0c;在python环境下运行此程序毫无问题但是QT调用却显示调用此函数出错&#xff0c;此时调用此.py文件内的其…...

2024.1.24力扣每日一题——美丽塔I

2024.1.24 题目来源我的题解方法一 暴力枚举方法二 单调栈前、后缀和 题目来源 力扣每日一题&#xff1b;题序&#xff1a;2865 我的题解 方法一 暴力枚举 将每个位置都作为山峰来进行遍历&#xff0c;计算每个山峰下的最大山脉数组和 时间复杂度&#xff1a;O( n 2 n^2 n2)…...

视频监控平台EasyCVR增加fMP4流媒体视频格式及其应用场景介绍

近期我们在视频监控管理平台EasyCVR系统中新增了HTTP-FMP4播放协议&#xff0c;今天我们就来聊聊该协议的特点和应用。 fMP4&#xff08;Fragmented MPEG-4&#xff09;是基于MPEG-4 Part 12的流媒体格式&#xff0c;是流媒体的一项重要技术&#xff0c;因为它能通过互联网传送…...

使用Python的pygame库实现迷宫游戏

使用Python的pygame库实现迷宫游戏 关于Python中pygame游戏模块的安装使用可见 https://blog.csdn.net/cnds123/article/details/119514520 先给出效果图&#xff1a; 这个游戏每次运行能自动随机生成迷宫布局。 在这个游戏中&#xff0c;玩家将使用键盘箭头键来移动&#x…...

Linux新手村必备!这些常用操作命令你掌握了吗?

在计算机的世界里&#xff0c;Linux操作系统以其强大的功能和灵活性受到了广大程序员和IT爱好者的喜爱。然而&#xff0c;对于初学者来说&#xff0c;Linux的操作命令可能会显得有些复杂和难以理解。 今天&#xff0c;我们就来一起探索一些Linux常用操作命令&#xff0c;让你的…...

ReactNative进阶(三十六):iPad横屏适配

文章目录 一、前言二、实现思路三、延伸阅读四、拓展阅读 一、前言 应用RN技术栈实现APP上线后&#xff0c;业务部门领导会上反馈未实现ipad横屏全屏展示&#xff0c;用户体验较差。由此&#xff0c;一场pad横屏全屏展示的APP调优工作由此开展。 二、实现思路 时间紧任务重&…...

jsx中使用插槽

1. jsx语法中使用插槽 以elementplus ElPopconfirm 为例 <el-popconfirm title"Are you sure to delete this?"><template #reference><el-button>Delete</el-button></template></el-popconfirm>使用 slots: {default: (dat…...

CentOS服务器拒绝SSH登录

当CentOS服务器拒绝SSH登录时&#xff0c;有几个可能的原因和解决方法&#xff1a; 检查网络连接&#xff1a;确保服务器与您的计算机之间的网络连接是正常的。您可以尝试使用其他网络连接或ping服务器以检查是否能够访问。 确认SSH服务正在运行&#xff1a;在服务器上确认SSH…...

React16源码: React中的completeUnitOfWork的源码实现

completeUnitOfWork 1 &#xff09;概述 各种不同类型组件的一个更新过程对应的是在执行 performUnitOfWork 里面的 beginWork 阶段它是去向下遍历一棵 fiber 树的一侧的子节点&#xff0c;然后遍历到叶子节点为止&#xff0c;以及 return 自己 child 的这种方式在 performUni…...

uniapp移动端——企业微信H5调用jssdk实现扫一扫,通过weixin-java-cp获取ticket签名,配置config

背景&#xff1a; 使用企业微信开发扫一扫功能 可信域名验证 (1)企业微信的可信域名需要和企业微信的备案主体一致。 域名备案主体可通过站长工具查看域名备案主体。https://icp.chinaz.com/ 企业微信备案主体可以咨询管理员 &#xff08;2&#xff09;通过nginx配置域名归…...

【前端基础--1】

为后面爬虫打基础 使用Visual Studio Code&#xff08;VS Code&#xff09; https://code.visualstudio.com/#alt-downloads 网页基础 创建一个html网页 新建一个文件 文件名后缀.html 书写网页模板 html:5 回车键&#xff08;或者Tab键&#xff09;英文感叹号! 回…...

E2 Mysql的基本操作和用户权限

一、实验目的: 要求掌握Mysql平台的基本操作和基本的权限管理。 二、实验要求: 1、基本硬件配置:英特尔Pentium III 以上,大于4G内存&#xff1b; 2、软件要求:Mysql&#xff1b; 3、时间:4小时&#xff1b; 4、撰写实验报告并按时提交。 三、实验内容: Group 1: 安装Mys…...

TCP 的三次握手和四次挥手

Java 面试题 TCP 三次握手 第一次握手&#xff1a;客户端向服务端发送SYN包。报文中标志位SYN1&#xff0c;序列号seqx&#xff08;x为随机整数&#xff09;。此时客户端进入了 SYN_SEND 同步已发送状态。 第二次握手&#xff1a;服务端回复客户端SYNACK包。报文中标志位SYN1&…...

mybatisplus做SQL拦截添加自定义排序

前言 工作中写的一段代码&#xff0c;备个份&#xff0c;以后兴许能直接用 功能描述&#xff1a;如果前端传入了排序规则&#xff0c;则优先按传入的字段进行排序&#xff0c;SQL原有的排序规则追加到末尾 注&#xff1a;我们项目里的分页查询&#xff0c;是基于XML的SQL执行的…...

代码随想录算法训练营第29天(回溯算法05 | * 491.递增子序列 * 46.全排列 * 47.全排列 II

回溯算法part05 491.递增子序列解题思路与 90.子集II 不同的点回溯三部曲 46.全排列解题思路遇到的难点思考 47.全排列 II解题思路注意点拓展需要加深理解的点&#xff08;需复习 小总结 491.递增子序列 本题和大家刚做过的90.子集II非常像&#xff0c;但又很不一样&#xff0c…...

mac docker desktop被禁用了,如何使用虚拟机lima运行docker

安装lima brew install lima创建配置 echo "\\ndynamic:\n big-sur:\n image: docker://docker:git\n linux:\n image: docker.io/limasoftware/ubuntu:20.04 \\n" > ~/.lima/default.yaml启动名叫default的虚拟机 limactl start default测试 limactl …...

Docker 离线安装指南

参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性&#xff0c;不同版本的Docker对内核版本有不同要求。例如&#xff0c;Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本&#xff0c;Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...

K8S认证|CKS题库+答案| 11. AppArmor

目录 11. AppArmor 免费获取并激活 CKA_v1.31_模拟系统 题目 开始操作&#xff1a; 1&#xff09;、切换集群 2&#xff09;、切换节点 3&#xff09;、切换到 apparmor 的目录 4&#xff09;、执行 apparmor 策略模块 5&#xff09;、修改 pod 文件 6&#xff09;、…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件&#xff0c;常用于在两个集合之间进行数据转移&#xff0c;如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model&#xff1a;绑定右侧列表的值&…...

多场景 OkHttpClient 管理器 - Android 网络通信解决方案

下面是一个完整的 Android 实现&#xff0c;展示如何创建和管理多个 OkHttpClient 实例&#xff0c;分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...

【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器

——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的​​一体化测试平台​​&#xff0c;覆盖应用全生命周期测试需求&#xff0c;主要提供五大核心能力&#xff1a; ​​测试类型​​​​检测目标​​​​关键指标​​功能体验基…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

智能在线客服平台:数字化时代企业连接用户的 AI 中枢

随着互联网技术的飞速发展&#xff0c;消费者期望能够随时随地与企业进行交流。在线客服平台作为连接企业与客户的重要桥梁&#xff0c;不仅优化了客户体验&#xff0c;还提升了企业的服务效率和市场竞争力。本文将探讨在线客服平台的重要性、技术进展、实际应用&#xff0c;并…...

WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)

一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解&#xff0c;适合用作学习或写简历项目背景说明。 &#x1f9e0; 一、概念简介&#xff1a;Solidity 合约开发 Solidity 是一种专门为 以太坊&#xff08;Ethereum&#xff09;平台编写智能合约的高级编…...

【论文阅读28】-CNN-BiLSTM-Attention-(2024)

本文把滑坡位移序列拆开、筛优质因子&#xff0c;再用 CNN-BiLSTM-Attention 来动态预测每个子序列&#xff0c;最后重构出总位移&#xff0c;预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵&#xff08;S…...

C# 求圆面积的程序(Program to find area of a circle)

给定半径r&#xff0c;求圆的面积。圆的面积应精确到小数点后5位。 例子&#xff1a; 输入&#xff1a;r 5 输出&#xff1a;78.53982 解释&#xff1a;由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982&#xff0c;因为我们只保留小数点后 5 位数字。 输…...