BAT面试题解析:数据库事务隔离级别如何区分脏读、幻读、不可重复读?

2026-04-30 17:247阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1312个文字,预计阅读时间需要6分钟。

BAT面试题解析:数据库事务隔离级别如何区分脏读、幻读、不可重复读?

第一类丢失更新:当A事务撤销时,将已提交的B事务的更新数据覆盖了。

例如:这里写图描述,此时取款事务A撤销,其余额恢复为1000,这样就丢失了更新。

第二类丢失更新:A事务覆盖了B事务的更新。

例如:这里写图描述,A事务覆盖了B事务的更新。

第一类丢失更新

A事务撤销时,把已经提交的B事务的更新数据覆盖了。例如:

这里写图片描述

这时候取款事务A撤销事务,余额恢复为1000,这就丢失了更新。

第二类丢失更新

A事务覆盖B事务已经提交的数据,造成B事务所做的操作丢失

这里写图片描述

如何解决

为了解决上述问题,数据库通过​​锁机制​​解决并发访问的问题。根据锁定对象不同:分为行级锁和表级锁;根据并发事务锁定的关系上看:分为共享锁定和独占锁定,共享锁定会防止独占锁定但允许其他的共享锁定。而独占锁定既防止共享锁定也防止其他独占锁定。为了更改数据,数据库必须在进行更改的行上施加行独占锁定,insert、update、delete 和 select for update 语句都会隐式采用必要的行锁定。

阅读全文

本文共计1312个文字,预计阅读时间需要6分钟。

BAT面试题解析:数据库事务隔离级别如何区分脏读、幻读、不可重复读?

第一类丢失更新:当A事务撤销时,将已提交的B事务的更新数据覆盖了。

例如:这里写图描述,此时取款事务A撤销,其余额恢复为1000,这样就丢失了更新。

第二类丢失更新:A事务覆盖了B事务的更新。

例如:这里写图描述,A事务覆盖了B事务的更新。

第一类丢失更新

A事务撤销时,把已经提交的B事务的更新数据覆盖了。例如:

这里写图片描述

这时候取款事务A撤销事务,余额恢复为1000,这就丢失了更新。

第二类丢失更新

A事务覆盖B事务已经提交的数据,造成B事务所做的操作丢失

这里写图片描述

如何解决

为了解决上述问题,数据库通过​​锁机制​​解决并发访问的问题。根据锁定对象不同:分为行级锁和表级锁;根据并发事务锁定的关系上看:分为共享锁定和独占锁定,共享锁定会防止独占锁定但允许其他的共享锁定。而独占锁定既防止共享锁定也防止其他独占锁定。为了更改数据,数据库必须在进行更改的行上施加行独占锁定,insert、update、delete 和 select for update 语句都会隐式采用必要的行锁定。

阅读全文