软考:数据库考点总结
结构冲突
在数据库领域,冲突主要指的是在并发操作中,多个事务试图同时访问或修改相同的数据资源,导致数据一致性、完整性和隔离性受到威胁。以下是数据库中常见的几种冲突类型:
-
读写冲突(Read-Write Conflict):
- 当一个事务在读数据的同时,另一个事务试图修改该数据,就会产生读写冲突。这种冲突可能导致“脏读”、“不可重复读”和“幻读”等问题。
-
写写冲突(Write-Write Conflict):
- 当多个事务同时试图修改同一数据时,就会产生写写冲突。这种冲突可能导致数据丢失或覆盖。
-
死锁(Deadlock):
- 两个或多个事务互相等待对方释放资源,导致系统进入停滞状态。
-
命名冲突(Naming Conflict):
- 在数据库设计中,两个或多个元素(如实体、属性、关系等)使用了相同的名字,导致混淆和错误。
-
属性冲突(Attribute Conflict):
- 在不同实体或关系中,属性具有相同的名字,但表示不同的意义或类型。
-
结构冲突(Structural Conflict):
- 在合并多个ER图时,实体之间的关系结构不一致,导致难以整合。
这些冲突类型对数据库的影响不同,处理方法也有所差异。数据库管理系统(DBMS)通过锁机制、事务隔离级别、死锁检测等手段来识别和处理这些冲突,以确保数据的一致性和系统的高效运行。
同一实体在不同的ER图中属性个数和排列次数不同,归属于结构冲突(真题考点)。
ACID特性:
- 数据库的ACID特性是确保数据库事务可靠性和一致性的四个关键属性。ACID是原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)的缩写。下面是每个特性的详细解释:
-
原子性(Atomicity):
- 原子性意味着事务中的所有操作要么全部完成,要么全部不完成。如果事务中的某个操作失败,整个事务将回滚到事务开始前的状态,就像这个事务从未执行过一样。这种特性确保了事务的不可分割性。
-
一致性(Consistency):
- 一致性确保事务的执行将数据库从一个一致的状态转换到另一个一致的状态。在事务开始之前和事务结束之后,数据库的完整性约束都必须得到满足。这意味着事务执行过程中不会违反任何预定义的规则和约束。
-
隔离性(Isolation):
- 隔离性保证了并发执行的事务之间的操作不会相互干扰。每个事务都像是在一个独立的环境中执行,对其他事务不可见,直到事务完成并提交。不同的数据库系统可能支持不同的隔离级别,如读未提交(Read Uncommitted)、读已提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。
-
持久性(Durability):
- 持久性意味着一旦事务被提交,它对数据库的修改就是永久性的,即使系统发生故障也不会丢失。数据库系统必须确保已提交的事务修改能够被保存到持久化存储中,通常是磁盘。
ACID特性是数据库事务处理的核心,它们共同工作以确保数据库的可靠性和数据的完整性。不同的数据库管理系统可能在实现这些特性时有所不同,但它们都必须遵循ACID原则来提供可靠的事务处理能力。
NoSQL
区别于关系型数据库,不保证ACID特性的数据库类型
1、列式数据库,通过列来组织和存储数据,比如Hbase
2、键值对数据库,比如Redis
3、文档型数据库
4、图数据库
特点:
1、易扩展
2、大数据量,高性能
3、灵活的数据模型,无需事前为要存储的数据建立字段,随时可用存储自定义的数据格式
4、高可用
体系架构,从上到下:
接口层,比如Rest,Map/Reduce,数据调用接口
数据逻辑层,数据逻辑表现形式
数据分布层,数据如何进行分布的,类似关系是数据库,CAP支持,数据中心支持,动态部署支持
数据持久层:数据的存储形式,比如内存,硬盘,内存和硬盘接口,定制可插拔四种形式。定制可插拔保证了数据存取具有较高的灵活性。
数据分布层三种支持的解释:
在数据库领域,数据分布层的CAP支持、数据中心支持和动态部署支持是构建高可用、高性能和可扩展数据库系统的关键特性。以下是对这些特性的详细解释:
-
CAP支持(Consistency, Availability, Partition tolerance):
- 一致性(Consistency):在分布式系统中,一致性指的是数据在多个节点之间保持同步。强一致性意味着任何时候读取的数据都是最新的,而弱一致性或最终一致性则允许数据在一段时间内不同步,但最终会达到一致状态。
- 可用性(Availability):指系统在任何时候都能响应用户的请求,即使在部分节点失败的情况下。高可用性系统能够容忍节点故障,而不影响整体服务。
- 分区容错性(Partition tolerance):在网络分区发生时,系统仍然能够继续运行。由于网络问题,分布式系统中的节点可能会被分割成不同的分区,分区容错性要求系统在这种情况下仍然能够工作。
-
数据中心支持:
- 数据中心支持涉及到数据库系统在
多个数据中心的部署和运行能力。这包括数据的跨数据中心复制、备份和恢复,以及在数据中心之间进行负载均衡和故障转移,以确保数据的高可用性和业务连续性。
- 数据中心支持涉及到数据库系统在
-
动态部署支持:
- 动态部署支持指的是数据库系统能够
根据业务需求和负载变化,动态地调整资源分配和配置。这包括动态增加或减少数据库节点、动态调整数据分区(Sharding)策略,以及在运行时切换数据源等。例如,dynamic-datasource是一个开源的 Spring Boot 多数据源启动器,它支持数据源分组、敏感信息加密、独立初始化表结构等功能,允许项目启动后动态增加或移除数据源。
- 动态部署支持指的是数据库系统能够
这些特性共同构成了现代数据库系统在分布式环境下的核心能力,使得数据库能够更好地应对大规模数据和高并发请求的挑战。
数据持久层的特点
数据持久层是软件架构中负责数据存储和管理的部分,它涉及到数据如何在系统中被保存和访问。数据的存储形式包括内存、硬盘、内存和硬盘的接口,以及定制可插拔存储解决方案。以下是这四种形式的简要说明和为什么定制可插拔形式能够提供较高的灵活性:
-
内存(Memory):
- 数据存储在RAM中,访问速度快,但成本较高,且数据在断电后会丢失。
-
硬盘(Hard Disk):
- 数据存储在硬盘驱动器上,成本较低,容量大,但访问速度比内存慢。
-
内存和硬盘接口(Memory-Disk Interface):
- 指的是缓存系统,如Redis或Memcached,它们作为内存和硬盘之间的桥梁,提供快速的数据访问,同时将数据持久化到硬盘。
-
定制可插拔(Customizable and Pluggable):
- 定制可插拔的数据存储解决方案允许开发者
根据特定需求定制存储系统,包括数据的存储格式、访问模式、持久化策略等。这种灵活性主要体现在以下几个方面:- 技术多样性:不同的应用可能需要不同的存储技术,如关系型数据库、NoSQL数据库、文件系统等。定制可插拔允许根据需求选择合适的存储技术。
- 扩展性:随着业务的发展,数据存储需求可能会变化。定制可插拔的解决方案可以根据需要轻松扩展或替换存储组件。
- 维护和升级:定制的解决方案可以更容易地进行维护和升级,因为它们通常与特定的业务逻辑紧密集成。
- 性能优化:定制解决方案可以根据特定的访问模式和数据特征进行优化,提高性能。
- 成本效益:通过定制,可以选择成本效益最高的存储解决方案,避免不必要的开销。
- 数据一致性和完整性:定制解决方案可以更好地控制数据的一致性和完整性,尤其是在复杂的事务处理中。
- 定制可插拔的数据存储解决方案允许开发者
定制可插拔的数据持久层解决方案提供了高度的灵活性和控制力,使得开发者能够根据应用的具体需求设计和实现最适合的数据存储策略。这种灵活性是构建高效、可靠和可维护系统的关键。
相关文章:
软考:数据库考点总结
结构冲突 在数据库领域,冲突主要指的是在并发操作中,多个事务试图同时访问或修改相同的数据资源,导致数据一致性、完整性和隔离性受到威胁。以下是数据库中常见的几种冲突类型: 读写冲突(Read-Write Conflict…...
Flash的语音ic型号有哪些?
深圳唯创知音电子有限公司在语音技术领域具有深厚的积累,其Flash语音IC产品凭借高性能和广泛的应用领域,在市场上占据了一席之地。以下是对该公司Flash语音IC产品的详细介绍: 一、产品概述 Flash语音IC是一种采用Flash存储技术的语音芯片&…...
10天进阶webpack---(1)为什么要有webpack
首先就是我们的代码是运行在浏览器上的,但是我们开发大多都是利用node进行开发的,在浏览器中并没有node提供的那些环境。这就早成了运行和开发上的不同步问题。 -----引言 浏览器模块化的问题: 效率问题:精细的模块划分带来了更…...
HTML CSS
目录 1. 什么是HTML 2. 什么是CSS ? 3. 基础标签 & 样式 3.1 新浪新闻-标题实现 3.1.1 标题排版 3.1.1.1 分析 3.1.1.2 标签 3.1.1.3 实现 3.1.2 标题样式 3.1.2.1 CSS引入方式 3.1.2.2 颜色表示 3.1.2.3 标题字体颜色 3.1.2.4 CSS选择器 3.1.2.5 发布时间字…...
第03章 MySQL的简单使用命令
一、MySQL的登录 1.1 服务的启动与停止 MySQL安装完毕之后,需要启动服务器进程,不然客户端无法连接数据库。 在前面的配置过程中,已经将MySQL安装为Windows服务,并且勾选当Windows启动、停止时,MySQL也 自动启动、停止…...
【C++动态规划】2435. 矩阵中和能被 K 整除的路径|1951
本文涉及知识点 C动态规划 LeetCode2435. 矩阵中和能被 K 整除的路径 给你一个下标从 0 开始的 m x n 整数矩阵 grid 和一个整数 k 。你从起点 (0, 0) 出发,每一步只能往 下 或者往 右 ,你想要到达终点 (m - 1, n - 1) 。 请你返回路径和能被 k 整除的…...
三、Kafka集群
一、Kafka集群的概念 1、目的 高并发、高可用、动态扩展。 主备数据架构、双活节点、灾备数据中心。 如果是服务的地理范围过大也可以使不同的集群节点服务不同的区域,降低网络延迟。 2、Kafka集群的基本概念 1)复制(镜像) kaf…...
[数据结构]堆
堆,本质是一颗完全二叉树。属于非线性结构。 代码实现可参考树的代码。 函数介绍: //此堆是小堆,大堆操作部分与小堆相反 void InitHeap(Heap* cat) {assert(cat);cat->arr NULL;cat->capacity cat->size 0; } void DestroyHeap(Heap* cat) {assert(…...
UDP-鼠李糖合成酶基因的克隆与鉴定-文献精读76
何首乌中UDP-鼠李糖合成酶基因FmRHM1/2的克隆与鉴定 摘要 UDP-鼠李糖是一种由UDP-鼠李糖合酶(RHM)催化合成的鼠李糖供体,而鼠李糖是鼠李糖苷化合物的重要组成部分,植物中只有少数基因编码的酶参与UDP-鼠李糖生物合成。本研究基于…...
【H2O2|全栈】JS进阶知识(四)Ajax
目录 前言 开篇语 准备工作 基本概念 原生JS使用AJAX 创建AJAX对象 设置请求方式和地址 设置请求头 发送请求 get方式发送 post方式发送 获取响应数据 AJAX状态码和HTTP状态消息 错误捕获 原生JS封装AJAX方法 $ 调用AJAX方法 结束语 前言 开篇语 本系列博客…...
Spring IOC的工作流程
Spring IOC的工作流程 好的,这个问题我会从几个方面来回答。 IOC是什么 Bean的声明方式 IOC的工作流程 IOC的全称是 Inversion Of Control,也就是控制反转,它的核心思想是把对象的管理权限交给容器。(展示图 1) &…...
从新手到专家:7款电脑平面设计软件评测
平面设计在时尚、广告等多个领域扮演着重要角色,而创作出独特且富有创意的设计作品则需要依赖优秀的电脑平面设计软件。市场上的电脑平面设计软件众多,每款软件都有其独到之处。本文将为你推荐几款值得关注的电脑平面设计软件,并分析它们的特…...
【C++】如何让C++字符串更快、C++的小字符串优化
二十三、如何让C字符串更快、C的小字符串优化 1、如何让C字符串更快? 如果程序中有很多字符串操作,比如格式化文本(日志记录),那是非常糟糕的,因为字符串操作是很慢的。字符串string和它相关的很多函数很可能会自动分配内存&…...
C++《list》
在本篇当中我们将学习STL中的list,在此list就是我们之前在数据结构学习过的链表,在本篇中我们要来了解list当中的成员函数该如何使用,由于list各个函数的接口和之前学习过的vector类型,因此在学习list的使用就较为轻松。在lis篇章…...
strongswan中METHOD定义
strongswan中使用METHOD来定义函数(方法),如下get_first函数定义。 METHOD(linked_list_t, get_first, status_t,private_linked_list_t *this, void **item) {if (this->count 0)return NOT_FOUND;*item this->first->value;ret…...
Rive 动画框架竟然支持响应式布局,全平台动画框架开启全新 UI 交互能力
没用过 Rive 的可能对于 Rive 还不熟悉,其实之前已经介绍过 Rive 好几次,例如《Rive 2 动画库「完全商业化」》 和《给掘金 Logo 快速添加动画效果》 等文章都介绍过 Rive ,之所以会接触 Rive 到, 也是因为多年前想在 Flutter 平台…...
MQ的详细大全知识点
MQ(Message Queue)是一种在分布式系统中广泛应用的消息中间件,它基于“先进先出”的数据结构原理,用于在不同系统之间传递消息。MQ通过提供接口给各个系统调用,实现了发送者和接收者之间的解耦,使得系统之间…...
AI图像相似性搜索对比:VIT, CLIP, DINO-v2, BLIP-2
图像相似性搜索的核心在于一个简单的想法:图像可以表示为高维空间中的向量。当两个图像相似时,它们的向量应该在这个空间中占据相似的位置。我们可以通过测量角度(或余弦相似度)来确定这些向量的相似程度。如果角度小,…...
【tomcat系列漏洞利用】
Tomcat 服务器是一个开源的轻量级Web应用服务器,在中小型系统和并发量小的场合下被普遍使用。主要组件:服务器Server,服务Service,连接器Connector、容器Container。连接器Connector和容器Container是Tomcat的核心。一个Container…...
前端学习-盒子模型(十八)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 盒子模型组成 边框 语法 边框简写 代码示例 表格的细线边框 语法 内边距 内边距复合写法 外边距 外边距典型应用 外边距合并 清除内外边距 总结 前…...
PCB设计中孔间距的DFM隐患,你避开了吗?
1. PCB孔间距设计:你可能忽略的定时炸弹 刚入行那会儿,我总觉得PCB设计就是把线路连通就行,直到亲眼看到产线上因为孔距问题报废的第三批板子——密密麻麻的破孔像蜂窝煤,有的孔边缘铜箔直接翘起来短路。老师傅指着板子说…...
从CCD到CMOS:HDR成像技术20年发展史与未来趋势
从CCD到CMOS:HDR成像技术20年演进与实战解析 在摄影器材展上,一位资深摄影师正用指尖轻抚不同年代的相机传感器——从2003年尼康D2H的CCD模块到2023年索尼A7RV的背照式CMOS,这个动作恰好勾勒出HDR技术演进的二十年轨迹。动态范围(…...
在六亩半,春天不是日历上的数字,而是泥土间的青草香
当城市里的春天还停留在气温起伏的天气预报里,六亩半手作文创园的春意,早已从土地深处探出头来。那是荠菜嫩芽拱开泥土的力道,是柳条抽出新绿的柔软,是孩子们蹲在田埂上、指尖沾满青草汁液的鲜活记忆。在这里,春天不是…...
FanControl:颠覆式开源风扇控制工具的全方位应用指南
FanControl:颠覆式开源风扇控制工具的全方位应用指南 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/…...
医学影像与卫星图的救星?深入聊聊JPEG-LS算法在边缘计算设备上的应用优势
JPEG-LS算法:边缘计算时代的医学影像与卫星图像压缩利器 当一台CT扫描仪每秒产生数百张16位深度的医学影像,或一颗遥感卫星每天传回数TB的高清地表数据时,传统的图像压缩方案往往面临两难选择——要么牺牲宝贵的诊断细节,要么耗尽…...
2026年必看:专业婚恋软件推荐,找到真爱不迷路
在当今快节奏的社会中,越来越多的高知青年面临着交友难、脱单难的问题。传统的社交方式往往难以满足他们对高质量伴侣的需求,而专业的婚恋软件则成为他们寻找真爱的重要途径。本文将重点推荐一款备受好评的婚恋软件——即恋App,并结合具体数据…...
IDEA 2023.3 配置 JavaWeb 项目完整流程:从新建到打包 War 的保姆级避坑指南
IDEA 2023.3 配置 JavaWeb 项目完整流程:从新建到打包 War 的保姆级避坑指南 作为一名长期使用 IntelliJ IDEA 进行 JavaWeb 开发的工程师,我深知在配置项目时可能遇到的各种"坑"。特别是对于刚接触 IDEA 的新手来说,从项目创建到最…...
每日算法题 17---205.同构字符串
题目 205.同构字符串 要求 给定两个字符串 s 和 t ,判断它们是否是同构的。如果 s 中的字符可以按某种映射关系替换得到 t ,那么这两个字符串是同构的。每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同字符不能映射到同一…...
硬核盘点|2026年好用AI论文写作工具榜单,毕业论文免费写还合规
2026 年实测 10 款主流 AI 论文工具,千笔AI以全流程覆盖 语义级降重 免费查重领跑综合榜;ThouPen 稳坐留学生毕业全流程工具头把交椅;免费工具中DeepSeek Scholar、豆包学术版表现亮眼,30 分钟即可生成万字高质量初稿࿰…...
信息安全毕设容易的项目选题汇总
0 选题推荐 - 网络与信息安全篇 毕业设计是大家学习生涯的最重要的里程碑,它不仅是对四年所学知识的综合运用,更是展示个人技术能力和创新思维的重要过程。选择一个合适的毕业设计题目至关重要,它应该既能体现你的专业能力,又能满…...
