多个事务并发执行时,在读取数据方面可能出现脏读、不可重复读、幻读等问题。
1.脏读:读到无效数据。
2.不可重复读:在数据库访问中,一个事务内的多次相同查询返回了不同数据。
3.幻读:指同一个事务内多次查询返回的结果集不一样。
不可重复度对应修改操作,幻读对应添加操作
🔴 Read uncommitted(读未提交)
一个事务督导读取到另一个事务未提交的数据(会产生脏读的问题)
🔴 Read committed (读已提交)
一个事务读取到另一个事务已提交的数据,在该事务内两次查询返回不同的数据(会产生不可重复读的问题)
🔴Repeatable read (重复读)
事务开启时,不再允许修改操作,解决不可重复读的问题。
🔴Serializable (序列化
串行执行,解决脏读、不可重复读、幻读的问题。
注意
❗事务的隔离级别越高,并发能力越低。
❗MySQL默认使用Repeatable read (重复读),可避免脏读和不可重复读,无法避免幻读。
❗MySQL版本升级后引入间隙锁,范围查询时会在该范围内添加间隙锁,阻塞其他任何操作,直到锁释放,虽然解决幻读问题,但是会影响数据库的并发性能(将隔离级别设置不可重复读可避免间隙锁,也就不会出现,影响并发性能的问题)