Mysql查询事务级别

举报
隔壁老汪 发表于 2022/06/24 00:25:19 2022/06/24
【摘要】 1.查看当前会话隔离级别   select @@tx_isolation; 2.查看系统当前隔离级别   select @@global.tx_isolation; 3.设置当前会话隔离级别   set session transaction isolatin level repea...

1.查看当前会话隔离级别

 

select @@tx_isolation;

2.查看系统当前隔离级别

 

select @@global.tx_isolation;

3.设置当前会话隔离级别

 

set session transaction isolatin level repeatable read;

 

4.设置系统当前隔离级别

 

set global transaction isolation level repeatable read;

 

5.命令行,开始事务时

 

set autocommit=off 或者 start transaction

 

关于隔离级别的理解

 

1.read uncommitted

 

可以看到未提交的数据(脏读),举个例子:别人说的话你都相信了,但是可能他只是说说,并不实际做。

 

2.read committed

 

读取提交的数据。但是,可能多次读取的数据结果不一致(不可重复读,幻读)。用读写的观点就是:读取的行数据,可以写。

 

3.repeatable read(MySQL默认隔离级别)

 

可以重复读取,但有幻读。读写观点:读取的数据行不可写,但是可以往表中新增数据。在MySQL中,其他事务新增的数据,看不到,不会产生幻读。采用多版本并发控制(MVCC)机制解决幻读问题。

 

4.serializable

 

可读,不可写。像java中的锁,写数据必须等待另一个事务结束。

文章来源: blog.csdn.net,作者:隔壁老瓦,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/wxb880114/article/details/105820849

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。