MySQL的事务隔离级别和锁-阿里云开发者社区

开发者社区> 数据库> 正文

MySQL的事务隔离级别和锁

简介: MySQL的事务隔离级别:Read Uncommitted【读未提交数据】Read Committed【读已提交数据】Repeatable Read【可重读】Serializable【可串行化】 查看MySQL的事务隔离级别:默认、全局和会话事务隔离级别: SELECT @@tx_isolation SELECT @@global.tx_isolation; SELECT @@ses

MySQL的事务隔离级别:Read Uncommitted【读未提交数据】Read Committed【读已提交数据】Repeatable Read【可重读】Serializable【可串行化】

查看MySQL的事务隔离级别:默认、全局和会话事务隔离级别:

SELECT @@tx_isolation
SELECT @@global.tx_isolation; 
SELECT @@session.tx_isolation;

mysql> select @@tx_isolation;
+-----------------+
| @@tx_isolation  |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)

设置mysql的事物隔离级别:

语法:


SET [SESSION | GLOBAL] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE}
默认设置隔离级别为下一个(未开始)事务设置隔离级别

mysql> set transaction isolation level read committed;
Query OK, 0 rows affected (0.05 sec)
或
mysql> set tx_isolation='read-committed';
Query OK, 0 rows affected (0.00 sec)
注:第一种无效。

需要dba的最高权限,用GLOBAL关键字设置隔离级别,在全局对从那点开始创建的所有新连接设置默认事务级别,用SESSION 关键字为将来在当前连接上执行的事务设置默认事务级别。任何客户端都能自由改变会话隔离级别,也可在事务的中间),或者为下一个事务设置隔离级别。 

mysql> set session transaction isolation level serializable;
Query OK, 0 rows affected (0.00 sec)
或
mysql> set @@session.tx_isolation='serializable';
Query OK, 0 rows affected (0.00 sec)
注:global类似。

锁机制:
共享锁:由读表操作加上的锁,加锁后其他用户只能获取该表或行的共享锁,不能获取排它锁,也就是说只能读不能写。
排它锁:由写表操作加上的锁,加锁后其他用户不能获取该表或行的任何锁,典型是mysql事务中。
锁的范围:
行锁: 对某行记录加上锁
表锁: 对整个表加上锁
组合起来就有:行级共享锁,表级共享锁,行级排他锁,表级排他锁。
四种隔离级别,开启事务,默认对表数据行加上行共享锁,其他事务对该表将只能进行读操作,而不能进行写操作,直到事务结束才会释放。
但SERIALIZABLE事务隔离级别最严厉,在进行查询时就会对表的每个读取行上加上共享锁。
详情学习推荐:MySQL数据库事务隔离级别

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章