专注于云服务器
VPS主机优惠测评
国内免备案虚拟主机

事务的四个隔离级别分别是什么

事务的四个隔离级别分别是:1、读取未提交内容(Read Uncommitted);2、读取提交内容(Read Committed);3、可重读(Repeatable Read);4、可串行化(Serializable)。

事务的四个隔离级别分别是什么

事务的四个隔离级别:

(推荐学习:mysql教程

一、Read Uncommitted — 读取未提交内容

  • 一个事务可以查看到未提交的内容

  • 常产生脏读问题(脏读:读取到其他事务未提交(执行)的内容)

对同一数据表开启A、B两个事务(A、B事务交叉) start transaction

A事务只查询数据表中内容,B事务做增删改操作但不commit(提交)

A事务依旧可以查询到表中的数据改变(查询到未提交的内容–脏读)

二、Read Committed — 读取提交内容

  • 一个事务只能查看已提交的内容

  • 常产生不可重复读的问题(不可重复读:同一事务中执行相同的select语句得到不同的结果)

对同一数据表开启A、B两个事务(A、B事务交叉) start transaction

A事务只查询数据表中内容,B事务做增删改操作但不commit(提交)

A事务查询不到表中的数据改变的内容

B事务提交

A查到的数据改变(A两次查询,产生不同的结果–不可重复读)

三、Repeatable Read — 可重读

  • 同一事务的多个实例并发读取数据时得到同一结果

  • MySQL的默认事务隔离级别

  • 常产生幻读问题(幻读:多次读取时产生不同结果(幻影行))

对同一数据表开启A、B两个事务(A、B事务交叉) start transaction

A事务只查询数据表中内容,B事务做增删改操作但不commit(提交)

A事务查询不到表中的数据改变的内容

B事务提交

A事务查询不到表中的数据改变的内容

A提交

A可查询到表中数据的改变

四、Serializable — 可串行化

  • 最高隔离级别

  • 给事务加上共享锁,同时只能有一个事务操作,解决幻读问题

  • 会导致大量超时和锁竞争问题

开启A事务

开启B事务时无法增删该操作

以上就是事务的四个隔离级别分别是什么的详细内容,更多请关注名铺123其它相关文章!

赞(0) 打赏
转载请注明出处:晓波笔记 » 事务的四个隔离级别分别是什么
分享到: 更多 (0)
megalayer云服务器

raksmart云服务器

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

晓波笔记-VPS主机,云服务器优惠促销测评

QQ:87304394

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏