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语句如下:
-
SELECT: 用于查询数据库中的数据,可以选择要查询的字段、表格和条件。 例如:SELECT * FROM 表名; // 查询表中的所有字段和数据 SELECT 列名1, 列名2 FROM 表名; // 查询指定字段的数据 SELECT * FROM 表名 WHERE 条件; // 查询满足条件的数据
-
INSERT INTO: 用于向数据库中插入新的数据。 例如:INSERT INTO 表名 (列名1, 列名2) VALUES (值1, 值2); // 插入指定字段的数据
-
UPDATE: 用于更新数据库中的数据。 例如:UPDATE 表名 SET 列名1 = 新值1, 列名2 = 新值2 WHERE 条件; // 更新满足条件的数据
-
DELETE: 用于删除数据库中的数据。 例如:DELETE FROM 表名 WHERE 条件; // 删除满足条件的数据
-
WHERE: 用于筛选满足条件的数据。 例如:SELECT * FROM 表名 WHERE 列名 = 值; // 查询满足条件的数据
-
ORDER BY: 用于对查询结果进行排序。 例如:SELECT * FROM 表名 ORDER BY 列名 ASC/DESC; // 按照指定列的升序/降序排序
-
GROUP BY: 用于对查询结果进行分组。 例如:SELECT 列名1, 列名2 FROM 表名 GROUP BY 列名1; // 按照指定列进行分组
-
JOIN: 用于将多个表格连接在一起进行查询。 例如:SELECT * FROM 表名1 JOIN 表名2 ON 表名1.列名 = 表名2.列名; // 连接两个表格查询数据
-
HAVING: 用于在GROUP BY语句中对分组后的结果进行筛选。 例如:SELECT 列名1, COUNT(列名2) FROM 表名 GROUP BY 列名1 HAVING COUNT(列名2) > 值; // 筛选满足条件的分组结果
-
DISTINCT: 用于去重查询结果。 例如:SELECT DISTINCT 列名 FROM 表名; // 查询指定字段的去重结果
以上是一些常用的数据库查询SQL语句,可以根据具体需求进行组合和扩展。
2.2 数据操作
常用的数据库数据操作SQL语句如下:
-
INSERT INTO: 用于向数据库中插入新的数据。 例如:INSERT INTO 表名 (列名1, 列名2) VALUES (值1, 值2); // 插入指定字段的数据
-
UPDATE: 用于更新数据库中的数据。 例如:UPDATE 表名 SET 列名1 = 新值1, 列名2 = 新值2 WHERE 条件; // 更新满足条件的数据
-
DELETE: 用于删除数据库中的数据。 例如:DELETE FROM 表名 WHERE 条件; // 删除满足条件的数据
-
TRUNCATE TABLE: 用于快速清空表中的数据,但不会回滚事务。 例如:TRUNCATE TABLE 表名; // 清空表中的数据
-
CREATE TABLE: 用于创建新的数据库表。 例如:CREATE TABLE 表名 (列名1 数据类型, 列名2 数据类型, ...); // 创建表结构
-
ALTER TABLE: 用于修改数据库表的结构。 例如:ALTER TABLE 表名 ADD 列名 数据类型; // 添加新的列 ALTER TABLE 表名 MODIFY 列名 数据类型; // 修改列的数据类型 ALTER TABLE 表名 DROP 列名; // 删除列
-
CREATE INDEX: 用于创建索引,加快查询速度。 例如:CREATE INDEX 索引名 ON 表名 (列名); // 在指定列上创建索引
-
DROP INDEX: 用于删除索引。 例如:DROP INDEX 索引名 ON 表名; // 删除指定表的索引
-
CREATE VIEW: 用于创建视图,可以将数据库中的数据以虚拟表的形式展现。 例如:CREATE VIEW 视图名 AS SELECT 列名1, 列名2 FROM 表名; // 创建视图
-
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.数据库基本概念 数据库(Database)是指存储、管理和组织数据的集合。它是一个组织化的、可持久化的数据集合,用于支持数据的存储、检索、更新和管理。 数据库系统(Database System)是建立在计算机上的数据管理系统&…...
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: 会显示页面源代…...
从零学习Hession RPC
为什么学习Hessian RPC? 存粹的RPC,只解决PRC的四个核心问题(1.网络通信2.协议 3.序列化 4.代理)Java写的HessianRPC落伍了,但是它的序列化方式还保存着,被Dubbo(Hessian Lite)使用。 被落伍,只…...
实施精细化管理的六大关键步骤
在当今高度竞争的市场环境中,企业若想脱颖而出,必须实现精细化管理。这不仅是为了提高效率,更是为了确保在复杂多变的市场中保持领先地位。通过以下六个关键步骤,企业可以构建一个强大的精细化管理体系,从而为未来的成…...
QT+C++环境调用python函数可以进入python环境和模块,但是调用功能函数错误
QTC环境使用Python.h调用python函数可以进入python环境和模块,但是调用功能函数错误 背景: 定义的python函数使用了其他库封装好的函数,在python环境下运行此程序毫无问题但是QT调用却显示调用此函数出错,此时调用此.py文件内的其…...
2024.1.24力扣每日一题——美丽塔I
2024.1.24 题目来源我的题解方法一 暴力枚举方法二 单调栈前、后缀和 题目来源 力扣每日一题;题序:2865 我的题解 方法一 暴力枚举 将每个位置都作为山峰来进行遍历,计算每个山峰下的最大山脉数组和 时间复杂度:O( n 2 n^2 n2)…...
视频监控平台EasyCVR增加fMP4流媒体视频格式及其应用场景介绍
近期我们在视频监控管理平台EasyCVR系统中新增了HTTP-FMP4播放协议,今天我们就来聊聊该协议的特点和应用。 fMP4(Fragmented MPEG-4)是基于MPEG-4 Part 12的流媒体格式,是流媒体的一项重要技术,因为它能通过互联网传送…...
使用Python的pygame库实现迷宫游戏
使用Python的pygame库实现迷宫游戏 关于Python中pygame游戏模块的安装使用可见 https://blog.csdn.net/cnds123/article/details/119514520 先给出效果图: 这个游戏每次运行能自动随机生成迷宫布局。 在这个游戏中,玩家将使用键盘箭头键来移动&#x…...
Linux新手村必备!这些常用操作命令你掌握了吗?
在计算机的世界里,Linux操作系统以其强大的功能和灵活性受到了广大程序员和IT爱好者的喜爱。然而,对于初学者来说,Linux的操作命令可能会显得有些复杂和难以理解。 今天,我们就来一起探索一些Linux常用操作命令,让你的…...
ReactNative进阶(三十六):iPad横屏适配
文章目录 一、前言二、实现思路三、延伸阅读四、拓展阅读 一、前言 应用RN技术栈实现APP上线后,业务部门领导会上反馈未实现ipad横屏全屏展示,用户体验较差。由此,一场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登录时,有几个可能的原因和解决方法: 检查网络连接:确保服务器与您的计算机之间的网络连接是正常的。您可以尝试使用其他网络连接或ping服务器以检查是否能够访问。 确认SSH服务正在运行:在服务器上确认SSH…...
React16源码: React中的completeUnitOfWork的源码实现
completeUnitOfWork 1 )概述 各种不同类型组件的一个更新过程对应的是在执行 performUnitOfWork 里面的 beginWork 阶段它是去向下遍历一棵 fiber 树的一侧的子节点,然后遍历到叶子节点为止,以及 return 自己 child 的这种方式在 performUni…...
uniapp移动端——企业微信H5调用jssdk实现扫一扫,通过weixin-java-cp获取ticket签名,配置config
背景: 使用企业微信开发扫一扫功能 可信域名验证 (1)企业微信的可信域名需要和企业微信的备案主体一致。 域名备案主体可通过站长工具查看域名备案主体。https://icp.chinaz.com/ 企业微信备案主体可以咨询管理员 (2)通过nginx配置域名归…...
【前端基础--1】
为后面爬虫打基础 使用Visual Studio Code(VS Code) https://code.visualstudio.com/#alt-downloads 网页基础 创建一个html网页 新建一个文件 文件名后缀.html 书写网页模板 html:5 回车键(或者Tab键)英文感叹号! 回…...
E2 Mysql的基本操作和用户权限
一、实验目的: 要求掌握Mysql平台的基本操作和基本的权限管理。 二、实验要求: 1、基本硬件配置:英特尔Pentium III 以上,大于4G内存; 2、软件要求:Mysql; 3、时间:4小时; 4、撰写实验报告并按时提交。 三、实验内容: Group 1: 安装Mys…...
TCP 的三次握手和四次挥手
Java 面试题 TCP 三次握手 第一次握手:客户端向服务端发送SYN包。报文中标志位SYN1,序列号seqx(x为随机整数)。此时客户端进入了 SYN_SEND 同步已发送状态。 第二次握手:服务端回复客户端SYNACK包。报文中标志位SYN1&…...
mybatisplus做SQL拦截添加自定义排序
前言 工作中写的一段代码,备个份,以后兴许能直接用 功能描述:如果前端传入了排序规则,则优先按传入的字段进行排序,SQL原有的排序规则追加到末尾 注:我们项目里的分页查询,是基于XML的SQL执行的…...
代码随想录算法训练营第29天(回溯算法05 | * 491.递增子序列 * 46.全排列 * 47.全排列 II
回溯算法part05 491.递增子序列解题思路与 90.子集II 不同的点回溯三部曲 46.全排列解题思路遇到的难点思考 47.全排列 II解题思路注意点拓展需要加深理解的点(需复习 小总结 491.递增子序列 本题和大家刚做过的90.子集II非常像,但又很不一样,…...
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 …...
基于FPGA的PID算法学习———实现PID比例控制算法
基于FPGA的PID算法学习 前言一、PID算法分析二、PID仿真分析1. PID代码2.PI代码3.P代码4.顶层5.测试文件6.仿真波形 总结 前言 学习内容:参考网站: PID算法控制 PID即:Proportional(比例)、Integral(积分&…...
为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?
在建筑行业,项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升,传统的管理模式已经难以满足现代工程的需求。过去,许多企业依赖手工记录、口头沟通和分散的信息管理,导致效率低下、成本失控、风险频发。例如&#…...
高等数学(下)题型笔记(八)空间解析几何与向量代数
目录 0 前言 1 向量的点乘 1.1 基本公式 1.2 例题 2 向量的叉乘 2.1 基础知识 2.2 例题 3 空间平面方程 3.1 基础知识 3.2 例题 4 空间直线方程 4.1 基础知识 4.2 例题 5 旋转曲面及其方程 5.1 基础知识 5.2 例题 6 空间曲面的法线与切平面 6.1 基础知识 6.2…...
Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
Neo4j 集群管理:原理、技术与最佳实践深度解析
Neo4j 的集群技术是其企业级高可用性、可扩展性和容错能力的核心。通过深入分析官方文档,本文将系统阐述其集群管理的核心原理、关键技术、实用技巧和行业最佳实践。 Neo4j 的 Causal Clustering 架构提供了一个强大而灵活的基石,用于构建高可用、可扩展且一致的图数据库服务…...
大学生职业发展与就业创业指导教学评价
这里是引用 作为软工2203/2204班的学生,我们非常感谢您在《大学生职业发展与就业创业指导》课程中的悉心教导。这门课程对我们即将面临实习和就业的工科学生来说至关重要,而您认真负责的教学态度,让课程的每一部分都充满了实用价值。 尤其让我…...
iOS性能调优实战:借助克魔(KeyMob)与常用工具深度洞察App瓶颈
在日常iOS开发过程中,性能问题往往是最令人头疼的一类Bug。尤其是在App上线前的压测阶段或是处理用户反馈的高发期,开发者往往需要面对卡顿、崩溃、能耗异常、日志混乱等一系列问题。这些问题表面上看似偶发,但背后往往隐藏着系统资源调度不当…...
Linux 中如何提取压缩文件 ?
Linux 是一种流行的开源操作系统,它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间,使数据传输更快。本指南将向您展示如何在 Linux 中提取不同类型的压缩文件。 1. Unpacking ZIP Files ZIP 文件是非常常见的,要在 …...
【C++特殊工具与技术】优化内存分配(一):C++中的内存分配
目录 一、C 内存的基本概念 1.1 内存的物理与逻辑结构 1.2 C 程序的内存区域划分 二、栈内存分配 2.1 栈内存的特点 2.2 栈内存分配示例 三、堆内存分配 3.1 new和delete操作符 4.2 内存泄漏与悬空指针问题 4.3 new和delete的重载 四、智能指针…...
