oracle-事务一系列理解

一个事务开始后,会被分配一个唯一的id号,xid,xid不仅是一个编号也是一个地址。

事务表

存在undo表空间的某一个段的段头块,最多存放47个事务,事务开始的时候,先将信息写入这个表,所以一个undo段最多纪录47个事务。

oracle尽量一个事务用一个回滚段,如果不够用,就复用。

可将段头dump出来(正常数据库也可以dump),文件名是以会话的编号组成


事务槽:

1一个事务开始的时候首先将xid写入空闲的undo段的段头的事务表中,同事写入uba地址

2 在所要修改的数据块的事务槽中写入xid事务信息, 一个数据块的事务槽最多放256个,事务槽中也有uba的地址。

3 回滚快(uba):将要修改的数据写入回滚快中,回滚块用完了用下一个使用链将其链起来,同时事务标中指向最新的uba。

所以xid回溯的首先是哪个回滚段的段头块,以及47行的哪一行,第几次覆盖(以免xid号重复)

dump出数据块流程

如果数据段段头没有事务槽,所有事物都会去回滚段段头去查询,造成拥挤。

事务提交方式

快速提交

箭头查询是通过xid,

相关推荐
我笔记10 分钟前
关系型数据库RDBMS与非关系型数据库NoSQL区别
数据库·oracle
PiscesCanon40 分钟前
达梦开启awr功能报错:[-7160]:Object [DBMS_WORKLOAD_REPOSITORY_DATA_LOW] is invalid
数据库·mysql
SZ1701102311 小时前
新机器 银河麒麟 安装 达梦数据库
数据库
清风6666661 小时前
基于单片机的图书馆智能座位管理平台
数据库·单片机·嵌入式硬件·毕业设计·课程设计
SirLancelot11 小时前
MongoDB-基本介绍(一)基本概念、特点、适用场景、技术选型
java·数据库·分布式·后端·mongodb·软件工程·软件构建
安冬的码畜日常1 小时前
【JUnit实战3_02】第二章:探索 JUnit 的核心功能(一)
数据库·junit·sqlserver
冻咸鱼2 小时前
数据库操作
数据库·mysql·数据库操作
duqiao_wang2 小时前
Mysql数据库系统库数据恢复
数据库·mysql
爬山算法2 小时前
Redis(64)Redis的Lua脚本有哪些常见场景?
数据库·redis·lua
掘金安东尼3 小时前
深入 Neo4j:从图数据库原理到企业知识引擎的实践指南
数据库·neo4j