InnoDB记录行格式的时候重点强调过:聚簇索引的记录除了会保存完整的用户数据以外,而且还会自动添加名为trx_id、roll_pointer的隐藏列,如果用户没有在表中定义主键以及UNIQUE键,还会自动添加一个名为row_id的隐藏列。所以一条记录在页面中的真实结构看起来就是这样的:其中的trx_id列其实还蛮好理解的,就是某个对这个聚簇索引记录做改动的语句所在的事务对应的事务id而已(此处的改动可以是INSERT、DELETE、UPDATE操作)。为了实现事务的原子性,InnoDB
存储引擎在实际进行增
、删
、改
一条记录时,都需要先把对应的undo
日志记下来。一般每对一条记录做一次改动,就对应着一条undo
日志,但在某些更新记录的操作中,也可能会对应着2条undo
日志,这个我们后边会仔细唠叨。一个事务在执行过程中可能新增
、删除
、更新
若干条记录,也就是说需要记录很多条对应的undo
日志,这些undo
日志会被从0
开始编号,也就是说根据生成的顺序分别被称为第0号undo日志、第1号undo日志、…、第n号undo日志等,这个编号也被称之为undo no
。
trx_id隐藏列
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《trx_id隐藏列》
文章链接:https://zhuji.vsping.com/5026.html
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
文章名称:《trx_id隐藏列》
文章链接:https://zhuji.vsping.com/5026.html
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。