【数据库】树形数据组织架构下的封锁并发控制,B树索引并发访问控制,树协议原理及案例分析

这篇具有很好参考价值的文章主要介绍了【数据库】树形数据组织架构下的封锁并发控制,B树索引并发访问控制,树协议原理及案例分析。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数据库并发访问树协议

专栏内容

  • 手写数据库toadb
    本专栏主要介绍如何从零开发,开发的步骤,以及开发过程中的涉及的原理,遇到的问题等,让大家能跟上并且可以一起开发,让每个需要的人成为参与者。
    本专栏会定期更新,对应的代码也会定期更新,每个阶段的代码会打上tag,方便阶段学习。

开源贡献

  • toadb开源库

个人主页:我的主页
管理社区:开源数据库
座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物.

前言

随着信息技术的飞速发展,数据已经渗透到各个领域,成为现代社会最重要的资产之一。在这个大数据时代,数据库理论在数据管理、存储和处理中发挥着至关重要的作用。然而,很多读者可能对数据库理论感到困惑,不知道如何选择合适的数据库,如何设计有效的数据库结构,以及如何处理和管理大量的数据。因此,本专栏旨在为读者提供一套全面、深入的数据库理论指南,帮助他们更好地理解和应用数据库技术。

数据库理论是研究如何有效地管理、存储和检索数据的学科。在现代信息化社会中,数据量呈指数级增长,如何高效地处理和管理这些数据成为一个重要的问题。同时,随着云计算、物联网、大数据等新兴技术的不断发展,数据库理论的重要性日益凸显。

因此,本专栏的分享希望可以提高大家对数据库理论的认识和理解,对于感兴趣的朋友带来帮助。

概述

有一类数据库元素,它的组织结构是树的形式,树中的各元素之间没有包含关系,如B-树索引数据的组织形式,对于此类数据的访问必须从树进行查找访问,这与之前介绍的数据库元素的层次结构,在加锁方式上不一样。

本文将重点介绍树形结构组织的数据的访问规则,封锁原理,以及一些优化的谈讨。

树结构的封锁不同点

  • 访问需要加锁; 在访问树形数据时,假如是B-树索引,为了保持读写操作的可串行化,需要进行封锁访问,锁模式如之前提到的读锁,写锁,更新锁;

  • 加锁粒度为节点;树的每个节点也是一个数据块,加锁粒度也是节点,更小到元组会带来更多不利,更大的粒度到整棵树,那几乎没有并发性了;

  • 加锁方式与2PL有区别;树的访问都是从根开始,然后一层层遍历,找到对应节点位置;那么加锁也从根开始,按之前介绍的两阶段锁规则,在使用前不能释放锁,那就意味着根节点没有并发性,这不利用索引的使用效率。如果确定不修改树节点,那么就可以提前释放根节点的锁,这就有悖2PL;

基于以上不同,对于树形组织的数据,专门使用树协议加锁方式,而不是2PL方式加锁,在确定当前节点还有空间时,就不会修改根节点,此时就可以提前释放根节点的锁,同样适用于中间节点,当然串行化的保证依赖于都从根往下顺次查找这一顺序。

树协议的规则

树协议由以下规则构成,假定访问树结构使用一种锁,用L(X)来表示加锁X节点;

  • 访问树结构时,第一个锁可以加在树中的任意节点;

  • 只有持有父节点的锁时,才能对其后续节点加锁;

  • 事务可以在任何时候解锁;

  • 不能对已解锁的节点重新加锁,即使此时持有父节点的锁也不行;

举例

【数据库】树形数据组织架构下的封锁并发控制,B树索引并发访问控制,树协议原理及案例分析,数据库概念,数据库,架构,b树,database,sql

并发三个事务,T1 从节点A开始移动,经过B,C,D;事务T2从B开始,目标是E节点;事务T3从E开始,移动到F和G;其中加锁是L(X),解锁是U(X)表示。

T1 T2 T3
L1(A);R1(A);
L1(B);R1(B);
L1©;R1©;
W1(A);U1(A);
L1(D);R1(D);
W1(B);U1(B);
L2(B);R2(B);
L3(E);R3(E);
W1(D);U1(D);
W1©;U1©;
L2(E) 被拒绝
L3(F);R3(F);
W3(F);U3(F);
L3(G);R3(G);
W3(E);U3(E);
L2(E);R2(E);
W3(G);U3(G);
W2(B);U2(B);
W2(E);U2(E);

这个例子中,事务T1,T2,T3是按照树协议进行并发调度,其中T2在加锁E节点时,与T3节点发生冲突,导致它被延迟,在T3释放E节点锁之后又得以继续执行。

树协议原理分析

树协议在调度中,锁涉及的事务中的必然包含一个串行动作序列,因为它们都是从上到下的访问顺序,这个可以用优先图来证明,如果优先图中没有环的存在,说明它等价一个可串行化的调度。

通过上面协议规则和树的访问顺序,在一棵树中,两个事务并发时,可以得出以下判断;

  • 假如有几个节点,两个事务都需要加锁,那么这几个节点上的加锁顺序是一样的;

因为两个事务访问的公共元素有两个或两个以上时,每个事务加锁的节点可以组成一个子树,两个子树的交也是一棵子树,访问时也是从最高节点开始,依次向下加锁,所有公共元素的加锁顺序是一致。

总结

对于树形组织的并发访问的控制,不能使用两阶段锁的模式,为了提升并发访问效率,通过树协议,可以提前释放当前节点路径上的锁。

结尾

非常感谢大家的支持,在浏览的同时别忘了留下您宝贵的评论,如果觉得值得鼓励,请点赞,收藏,我会更加努力!

作者邮箱:study@senllang.onaliyun.com
如有错误或者疏漏欢迎指出,互相学习。文章来源地址https://www.toymoban.com/news/detail-764749.html

到了这里,关于【数据库】树形数据组织架构下的封锁并发控制,B树索引并发访问控制,树协议原理及案例分析的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • HDFS组织架构及相关介绍

    HDFS(Hadoop Distributed File System)是Hadoop生态系统中一个高可靠性、高吞吐量、高容错性的分布式文件系统。它最初是Google发明的GFS(Google File System)的实现, 根据Apache Hadoop Project组织架构,HDFS的组织架构如下: Client Client是与用户交互的第一层,它处理和提供文件系统或者存储集群

    2024年02月11日
    浏览(40)
  • ruoyi若依 组织架构设计--[ 菜单管理 ]

    1.部门表 ancestors 字段。 添加这个字段, 方便列举所有子部门 2.用户信息表 添加dept_id。用于根据 部门树 ,查询所有的用户。另一方面,也是可以做 数据权限 3.岗位表 4.角色表 5.菜单表 6.用户角色关联表 7.角色菜单关联表 8.角色部门关联表 9.用户岗位关联表 需求是 超级管理

    2024年02月12日
    浏览(45)
  • [架构之路-243]:目标系统 - 纵向分层 - 架构是表面轮廓、内部骨架、未来蓝图,企业组织架构、信息系统架构、软件架构、应用程序就架构

    目录 一、什么是架构 1.1 架构是表面轮廓 1.2 架构是内部骨架 1.3 架构是蓝图,是愿景 1.4 架构是数据流、控制流、管理流、同步流 1.5 数据、控制、同步、管理的比较 二、架构的层级 2.1 企业组织架构 2.2 企业系统架构 2.2 信息系统架构 2.3 软件架构 2.4 应用程序的架构 三、软

    2024年02月08日
    浏览(57)
  • 怎样优雅地增删查改(五):按组织架构查询

    之前我们实现了Employee,Alarm管理模块以及通用查询应用层。 Employee的集合查询业务,是通过重写CreateFilteredQueryAsync方法,来实现按组织架构查询的过滤条件。 我们将这段逻辑代码提取到通用查询应用层中,便可实现在任何业务的按组织架构查询。 查询依据 在Abp中,组织架构

    2024年02月16日
    浏览(43)
  • 如何在Microsoft Word中制作组织架构图

    如果要说明公司或组织中的报告关系,可以创建一个使用组织结构图布局的 SmartArt 图形,如组织结构图。 注意:绘制组织结构图的另一种方法是使用 Microsoft 绘图应用程序 Visio。 使用 SmartArt 图形在 Excel、Outlook、PowerPoint 或 Word 中创建组织结构图,以显示组织中的报告关

    2024年02月12日
    浏览(30)
  • 软件测试基础(五) 之 了解测试团队的组织架构

    今天来了解一下软件测试团队的组织架构模式到底是什么样子。   一个公司软件测试的组织架构,可能会决定你未来的成长空间,同时也决定了我们的工作模式到底是什么样子。   现在测试行业内通常测试团队的组织架构主要分成两种, 一种叫做金字塔式管理模式,一

    2024年02月07日
    浏览(46)
  • 阿里组织架构迎来巨变!拆分为六大业务,或可分别独立上市

    “1+6+N”组织调整是阿里巴巴“24年来最重要的一次组织变革”,六大业务集团及业务公司可以独立融资或独立上市,意味着阿里的整体估值将得到大幅提升。 马云回国、阿里巴巴宣布启动“1+6+N”组织调整、具备条件的业务集团和公司将独立上市……一系列有关阿里的消息在

    2024年02月06日
    浏览(65)
  • 汇编语言第一讲:计算机的组织架构和汇编语言介绍

    第一讲:计算机的组织架构和汇编语言介绍 汇编语言 计算机组织架构 数字电路 术语回顾 数制 数字电路 硬件电路 数字电路的问题 汇编语言的开始 程序的节(sections) 调用操作系统的系统调用 列出文件(Listing files) 汇编和链接 调试汇编程序 反汇编现有的程序 附录 课程资源

    2024年04月09日
    浏览(52)
  • PMP组织架构分类(强矩阵弱矩阵等)及项目经理权力与职能经理对比,一看必懂

    PMP组织架构中一般分类 :职能型,项目型,矩阵型(包括弱矩阵型、强矩阵型、平衡型矩阵)。 先重点来说说弱/强 矩阵型: 矩阵型划分强弱矩阵(事务急迫与难度): 弱矩阵: 一般为较简单或不紧急的项目 强矩阵: 一般为较复杂或较紧急的项目 平衡矩阵: 各方面都相对

    2024年02月06日
    浏览(53)
  • Go-Ldap-Admin | openLDAP 同步钉钉、企业微信、飞书组织架构实践和部分小坑

    目录 一、Docker-compose快速拉起demo测试环境 二、原生部署流程 安装MySQL:5.7数据库 安装openLDAP 修改域名,新增con.ldif 创建一个组织 安装OpenResty 下载后端 下载前端 部署后端 部署前端 三、管理动态字段 钉钉 企业微信 飞书 四、部分报错 Go-Ldap-Admin官网:Go-Ldap-Admin 本文用于记

    2024年02月07日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包