InnoDB支持SQL1992标准中的四种隔离级别:READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ、SERIALIZABLE。默认的隔离级别是REPEATABLE READ。
通过SET TRANSACTION命令可以改变默认的隔离级别,为了让这种改变对所有用户的所有连接都生效,需要加上--transaction-isolation选项。
InnoDB通过不同的加锁策略来实现不同的隔离级别
REPEATABLE READ
这是InnoDB默认的隔离级别。在一个事务中,一致读会读到该事务中第一次读到的那个快照。这就意味着,在同一个事务中多次执行普通的SELECT语句返回的结果是一致的。
对于加锁读(SELECT ... FOR UPDATE或者SELECT ... LOCK IN SHARE MODE)、更新、删除语句,锁取决于语句是否使用了唯一索引或者范围类的检索条件。
- 对于用唯一索引作为检索条件,InnoDB只会锁发现的索引记录,而不会锁它前面的间隙
- 对于其它的检索条件,InnoDB锁定扫描的索引范围,用间隙锁或者next-key锁来阻塞其它会话向这个范围内的间隙中插入数据
注:本文内容来自互联网,旨在为开发者提供分享、交流的平台。如有涉及文章版权等事宜,请你联系站长进行处理。