查看和设置mysql 事务的隔离级别

1.数据库事务的隔离级别

1)级别1:read uncommitted : 
   读取尚未提交的数据,哪个问题都不能解决

2)级别2:read committed:
   读取已经提交的数据(可以读取到其他事务提交的update更新和insert新增),可以解决脏读,oracle默认的

3)级别4:repeatable read:
   重读读取(只能读取其他事务已经提交的insert新增数据),可以解决脏读和不可重复读,mysql默认的

4)级别8:serializable:
   串行化:可以解决 脏读 不可重复读 和 虚读---相当于锁表


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

SELECT @@tx_isolation


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

set session transaction isolation level repeatable read;


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

select @@global.tx_isolation;


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

set global transaction isolation level repeatable read;



关于隔离级别的理解

 

1.read uncommitted

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

 

2.read committed

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

 

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

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

 

4.serializable

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





  • 9
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值