MySQL事务隔离级别

多个事务并发执行时,在读取数据方面可能出现脏读、不可重复读、幻读等问题。

1.脏读:读到无效数据。

2.不可重复读:在数据库访问中,一个事务内的多次相同查询返回了不同数据

3.幻读:指同一个事务内多次查询返回的结果集不一样。

不可重复度对应修改操作,幻读对应添加操作

🔴 Read uncommitted(读未提交)

一个事务督导读取到另一个事务未提交的数据(会产生脏读的问题)

🔴 Read committed (读已提交)

一个事务读取到另一个事务已提交的数据,在该事务内两次查询返回不同的数据(会产生不可重复读的问题)

🔴Repeatable read (重复读)

事务开启时,不再允许修改操作,解决不可重复读的问题。

🔴Serializable (序列化

串行执行,解决脏读、不可重复读、幻读的问题。

注意

❗事务的隔离级别越高,并发能力越低。

❗MySQL默认使用Repeatable read (重复读),可避免脏读和不可重复读,无法避免幻读。

❗MySQL版本升级后引入间隙锁,范围查询时会在该范围内添加间隙锁,阻塞其他任何操作,直到锁释放,虽然解决幻读问题,但是会影响数据库的并发性能(将隔离级别设置不可重复读可避免间隙锁,也就不会出现,影响并发性能的问题)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值