温州自助建站公司/谷歌关键词查询工具
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 …...

sublime text 开启vim模式
sublime text 开启vim模式 打开配置文件 mac下点击菜单栏 Sublime Text -> Settings... -> Settings 修改配置文件并保存 添加配置 // 开启vim模式 "ignored_packages": [// "Vintage", ], // 以命令模式打开文件 "vintage_start_in_comman…...

JS词法结构
编程语言的词法结构是一套基础性规则,用来描述如何使用这门语言来编写程序。作为语法的基础,它规定了诸如变量名是什么样的、怎么写注释,以及程序语句之间如何分隔等规则。 2.1程序的文本 JS区分大小写 JS忽略程序记号(token&am…...

程序媛的mac修炼手册-- 如何用Python节省WPS会员费
上篇分享了如何用微博爬虫,咱举例爬了女明星江疏影的微博数据。今天就用这些数据,给大家安利一下怎么用Python实现WPS中部分Excel付费功能。 MacOS系统自带的工具,绝大多数都非常顶,除Numbers外。当然,page比起word来&…...

ASP.NET Core NE8实现HTTP Upgrade和HTTP CONNECT代理服务器
看到一个文章[Go] 不到 100 行代码实现一个支持 CONNECT 动词的 HTTP 服务器 在NET8中如何实现 创建项目为MiniApi 编辑Program.cs文件。 var builder WebApplication.CreateSlimBuilder(args);var app builder.Build();// 将HTTP请求通过协议升级机制转为远程TCP请求&…...

apipost和curl收不到服务器响应的HTTP/1.1 404 Not Found
windows的apipost发送请求后,服务器响应了HTTP/1.1 404 Not Found,但是apipost一直显示发送中。 linux上的curl也一样。 使用wireshark抓包发现收到了响应,但是wireshark识别不了(图中是回应404后关闭了连接)ÿ…...

javascript:计算一个坐标数组的最小值点、最大值点、中心点
作者:CSDN _乐多_ 本文将介绍使用 javascript 语言计算一个坐标数组的最小值点、最大值点、中心点的代码。 文章目录 一、代码 一、代码 function calculateCenterPoint(points) {if (points.length 0) {return null;}let sumX 0;let sumY 0;let sumZ 0;for …...

使用远程工具连接Linux系统——使用Root用户登录
1、启动虚拟机,输入以下命令 进入root用户 sudo su或 su root修改ssh配置文件 vim /etc/ssh/sshd_config找到PermitRootLogin 并用#注释掉当前行 # PermitRootLogin prohibit-password添加: PermitRootLogin yes键入esc输入:wq保存退出 2、重启服…...

JuiceSSH结合内网穿透实现移动端设备公网远程访问Linux虚拟机
文章目录 1. Linux安装cpolar2. 创建公网SSH连接地址3. JuiceSSH公网远程连接4. 固定连接SSH公网地址5. SSH固定地址连接测试 处于内网的虚拟机如何被外网访问呢?如何手机就能访问虚拟机呢? cpolarJuiceSSH 实现手机端远程连接Linux虚拟机(内网穿透,手机端连接Linux虚拟机) …...

06-枚举和模式匹配
上一篇:05-使用结构体构建相关数据 在本章中,我们将介绍枚举。枚举允许你通过枚举其可能的变体来定义一种类型。首先,我们将定义并使用一个枚举,以展示枚举如何与数据一起编码意义。接下来,我们将探索一个特别有用的枚…...

【C/C++】C/C++编程——C++ 开发环境搭建
C的开发环境种类繁多,以下是一些常见的C 集成开发环境: AppCode :构建与JetBrains’ IntelliJ IDEA 平台上的用于Objective-C,C,C,Java和Java开发的集成开发环境CLion:来自JetBrains的跨平台的C/C的集成开…...