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

【软考-架构】3.3、模式分解-事务并发-封锁协议

✨资料&文章更新✨
GitHub地址:https://github.com/tyronczt/system_architect

文章目录

  • 模式分解(难点)
  • 无损分解
  • 💯考试真题
  • 并发控制
  • 封锁协议
  • 💯考试真题
    • 第一题
    • 第二题

模式分解(难点)

保持函数依赖分解:分解出来的多个关系模式,保持原来的依赖集不变。

无损分解

无损分解:分解后的关系模式能够还原出原关系模式,就是无损分解,不能还原就是有损。

当分解为两个关系模式,可以通过以下定理判断是否无损分解:

定理:如果R的分解为p={R1,R2},F为R所满足的函数依赖集合,分解p具有无损连接性的充分必要条件是R1 ∩ R2->(R1-R2)或者R1 ∩ R2->(R2-R1)

💯考试真题

候选关键字分析

候选关键字的求法:根据依赖集,找出从未在右边出现过的属性,必然是候选键之一,以该属性为基础,根据依赖集依次扩展,看能否遍历所有属性,将无法遍历的加入候选键中。

  • 属性集 U={A,B,C,D,E},函数依赖集 F={B→A,D→A,A→E,AC→B}。
  • 候选键需满足:能推导出所有属性且极小。
    • CD 是候选键:
  • CD→D→A→E,且 AC→B(通过 C∈CD 和 A∈D+)。
    • 其他组合(如 BC、AC)无法推导出所有属性。
  • 结论:候选关键字为 A(选项 A:CD)。

无损性判断

公式:R1 ∩ R2->(R1-R2)或者R1 ∩ R2->(R2-R1)

R1 ∩ R2 = C ; R1-R2 = ABE ; R2-R1 = D;

C → ABE & C → D 都不成立,所以为有损分解;

函数依赖

原依赖 D→A 无法在 R1 或 R2 中保留(因 D 仅在 R2,而 A 不在 R2),依赖未完全保持。

最终答案

  • 候选关键字:A. CD
  • 分解性质:D. 不具有无损连接性,也不保持函数依赖

并发控制

原子性、一致性、隔离性、持续性。

封锁协议

X锁是排它锁(写锁)。若事务T对数据对象A加上X锁,则只允许T读取和修改A,其他事务都不能再对A加任何类型的锁,直到T释放A上的锁。

S锁是共享锁(读锁)。若事务T对数据对象A加上S锁,则只允许T读取A,但不能修改A,其他事务只能再对A加S锁(也即能读不能修改),直到T释放A上的S锁。

💯考试真题

第一题

答案:C

第二题

排他锁(X锁)是独占锁,禁止其他所有锁;共享锁(S锁)允许其他共享锁,但禁止排他锁。

答案:D、C


http://www.kler.cn/a/583713.html

相关文章:

  • C# WPF 基础知识学习(一)
  • 贪心算法(5)(java)k次取反后最大化的数组和
  • 什么是AI?AI能对我们生活产生哪些影响?
  • LeetCode 112. 路径总和 II java题解
  • 如何用Docker容器化Java应用?Spring Boot实战指南
  • Spring Boot 约定大于配置:实现自定义配置
  • HCIP复习拓扑练习(修改版)
  • 【3DGS】SuperSplat本地运行+修改监听端口+导入ply模型+修剪模型+在线渲染3DGS网站推荐
  • 设计模式C++
  • Java 8新特性:Lambda表达式与Stream API实战
  • OEM SQL Details and Session Details 5s 或者parallel 才会在sql monitor显示
  • Aliyun CTF 2025 web 复现
  • uniapp,自绘仪表盘组件(基础篇)
  • BEVDepth: Acquisition of Reliable Depth for Multi-view 3D Object Detection 论文阅读
  • c# txt文档的实时显示,用来查看发送接收指令
  • 如何简单获取三个月免费试用的SSL证书
  • AI对前端开发的冲击
  • 第十课:项目部署与运维:从开发到生产
  • 仅仅使用pytorch来手撕transformer架构(1):位置编码的类的实现和向前传播
  • springcloud gateway搭建及动态获取nacos注册的服务信息信息