一张时序图看懂:脏读、不可重复读

本文详细介绍了数据库中共享锁与排他锁的工作原理。共享锁允许多个读操作同时进行,但阻止写操作;排他锁则独占资源,禁止其他任何操作。通过具体语法示例,加深了对两种锁的理解。

[必读] 共享锁与排他锁

首先说明:数据库的增删改操作默认都会加排他锁,而查询不会加任何锁。

  • 共享锁

    对某一资源加共享锁,自身可以读该资源,其他人也可以读该资源(也可以再继续加共享锁,即 共享锁可多个共存),但无法修改。要想修改就必须等所有共享锁都释放完之后。
    语法为:select * from table lock in share mode

  • 排他锁

    对某一资源加排他锁,自身可以进行增删改查,其他人无法进行任何操作。
    语法为:select * from table for update

关于共享锁与排他锁的介绍,想了解更多请移步:浅谈Mysql共享锁、排他锁、悲观锁、乐观锁及其使用场景

[经典] 时序图

如下需注意:

  • commit but exception:表示在代码中,假如遇到提交事务时出现报错
  • commit and rollback:表示在代码中,假如遇到提交事务时出现报错,因此进行回滚

一张时序图:脏读、不可重复读及解决实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值