暂无图片
返回数说广场
杨凯同学
2024-07-08
不管是加表锁,还是加行锁,如果不能立即获得锁,加锁事务都需要进入锁等待状态。 事务进入锁等待状态,需要用锁结构来排队。和立即获得锁时的锁结构一样,这个锁结构的各属性都已经初始化完成。不同之处在于,它被设置为等待状态。 表锁、行锁处于等待状态时,都不能共用锁结构,而是需要申请一个新的锁结构。 每个事务对象初始化时,会预先创建 8 个表锁结构、8 个行锁结构。 事务执行过程中加锁,需要申请新的锁结构时,如果预先创建的表锁结构、行锁结构还有空闲的,可以直接找一个对应的空闲锁结构来使用,没有空闲的,则需要创建一个对应的锁结构。 事务拿到新的锁结构之后,会把 type_mode 属性的第 9 位设置为 1,表示这个锁结构处于等待状态。
0
暂无图片 1
122
分享

评论

热门数说