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

开发者社区> tony~tian> 正文

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数据库事务隔离级别

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

相关文章
RocketMQ与MYSQL事务消息整合
rocketmq事务消息与mysql事物整合
8511 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
10061 0
MySql事务及原理详解
MySql事务及原理详解
9 0
Java提升篇-事务隔离级别和传播机制
问题的提出 为了保证并发操作数据的正确性及一致性,SQL规范于1992年提出了数据库事务隔离级别。 事务隔离级别分类 事务隔离级别由低往高可分为以下几类 READ UNCOMMITTED,读取未提交的数据。
971 0
事务隔离级别
事务隔离级别: @Transactional(isolation = Isolation.READ_UNCOMMITTED):读取未提交数据(会出现脏读, 不可重复读) 基本不使用 @Transactional(isolation = Isolation.
1514 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
10882 0
Mysql 事务隔离级别 与 读出现的问题实验
Mysql 事务隔离级别 与 读出现的问题实验 读未提交:一个事务的隔离级别为‘读未提交’,它可以读取其他事务未提交的数据 读已提交:一个事务的隔离级别为‘读已提交’,它只可以读其他事务已提交的数据 可重复读:一个事务的隔离级别为‘可重复读’,不关心其他事务的操作,整个事务内读取的数据一致。
2428 0
重新学习MySQL数据库6:浅谈MySQL的中事务与锁
『浅入深出』MySQL 中事务的实现   在关系型数据库中,事务的重要性不言而喻,只要对数据库稍有了解的人都知道事务具有 ACID 四个基本属性,而我们不知道的可能就是数据库是如何实现这四个属性的;在这篇文章中,我们将对事务的实现进行分析,尝试理解数据库是如何实现事务的,当然我们也会在文章中简单对 MySQL 中对 ACID 的实现进行简单的介绍。
1431 0
+关注
tony~tian
追求完美,追求自由!
122
文章
2
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载