mysql innodb下的锁及隔离级别

Posted 叶落kiss

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql innodb下的锁及隔离级别相关的知识,希望对你有一定的参考价值。

innodb引擎支持行级锁。

锁实现了事务之间的隔离功能。

悲观锁,排他锁种类:

  1. row-level lock 或record lock    都是指的行级锁

  2. gap                 间隙锁

  3. next-lock              下键锁

 

 

 

隔离级别(隔离的是数据的读,默认的级别是RR模式):也称读的隔离性级别

查看数据库当前隔离级别:select @@tx_isolation;

  1. RU  读未递交,可脏读

  2. RC  读已递交,可幻读,隔离了脏读

  3. RR  可重复读,隔离了幻读。利用的是undo的快照技术+GAP间隙锁+nextlock下键锁

  4. SE  串行化,可以防止死锁,但并发事务性能差

 

配置文件中设置隔离级别:vim /xx/my.cnf中添加

  1. transaction_isolation=read-uncommitted

  2. transaction_isolation=read-committed

  3. transaction_isolation=repeatable-read

 

以上是关于mysql innodb下的锁及隔离级别的主要内容,如果未能解决你的问题,请参考以下文章

mysql 开发进阶篇系列 12 锁问题(隔离级别下锁的差异)

MySQL- 锁

锁-隔离级别的一些补充

啥是 MySQL 事务隔离级别?

你了解MySQL 的事务隔离级别吗?

Mysql:RR隔离级别下的幻读