数据库中隔离级别

一、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事务时无法增删该操作
事务隔离级别脏读不可重复读幻读
Read Uncommitted
Read Committed
Repeatable Read
Serializable
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值