oracle ITL槽

1.每个数据块头都有一个ITL(interested transaction list),ITL里记录了在本数据块内拥有行锁(row lock)、已提交的记录和未提交的记录的事务信息。
2.ITL指向undo段里的事务表,事务表里有对数据库做的所有记录。
3.从某种意义上说,数据块头利用ITL记录了一段时间以来事务对数据块所做的改变。
4.Oracle的锁机制是一种轻量级的锁定机制,不是通过构建锁列表来进行数据的锁定管理,而是直接将锁作为数据块的属性,存储在数据块首部。这个是通过ITL来实现的,一个事务要修改块中的数据,必须获得该块中的一个itl(通过initrans预先分配的或者是通过free space构建的)。
5.ITL槽的事务提交或回滚后,才可以被其他事务覆盖,当新事务发现不够ITL槽时,会动态创建一个新的ITL槽(如果存在空闲空间)。
initrans:每个数据块默认ITL槽数目,默认值为2
maxtrans:ITL会根据需要动态拓展,最多达到maxtrans数量(假设块上有足够的空闲空间)。
6.每当一个事务要更新数据块里的数据时,必须先得到一个ITL槽,然后将当前事务ID,事务所用的undo数据块地址,SCN号,当前事务是否提交等信息写到ITL槽里。也就是说ITL槽包含信息: 1.事务ID;2.事务所用UNDO块地址;3.SCN号;4.事务是否提交标记。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26366371/viewspace-2062138/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/26366371/viewspace-2062138/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值