SQL隔离级别和锁

脏读:读完后,别人回滚了,读出来的数据无效
不可重复读:读第一次和第二次的结果不一样
幻读:第二次读多了一行(几行)

https://www.cnblogs.com/qanholas/p/3227220.html
修正一点:在Read Commited级别中,读锁是读完就释放,写锁是事务结束才释放

1.读未提交:
特点:不上锁
问题:脏读,不可重复读,幻读

2.读提交:
特点:读前先取读锁,读后释放;写前先取写锁,事务提交后才释放
解决了:
脏读:事务B修改但未提交,锁还在手上,事务A无法读,也就产生不了脏读
问题:不可重复读,幻读

3.可重复读
特点:读写前先取读写锁,事务提交后才释放锁
解决了:
不可重复读:因为读了之后不释放读锁,因此别的事务也就无法写
问题:幻读

4.序列化
特点:读写前对整张表取读写锁,事务提交后才释放锁
解决了:
幻读:对整张表上锁,别的事务也就无法插入

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值