java 乐观锁数据库,数据库的乐观锁悲观锁

锁是网络数据库中的一个非常重要的概念,当多个用户同时对数据库并发操作时,会带来数据不一致的问题,所以,锁主要用于多用户环境下保证数据库完整性和一致性

数据库锁出现的目的:处理并发问题

并发控制的主要采用的技术手段:乐观锁、悲观锁和时间戳。

锁分类

从数据库系统角度分为三种:排他锁、共享锁、更新锁。 从程序员角度分为两种:一种是悲观锁,一种乐观锁

悲观锁(Pessimistic Lock)

顾名思义,很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人拿这个数据就会block(阻塞),直到它拿锁。

889c768f9a8f57f05fffd9b6fab3408f.png

传统的关系数据库里用到了很多这种锁机制,比如行锁、表锁、读锁、写锁等,都是在操作之前先上锁。

悲观锁按使用性质划分

共享锁(Share Lock

S锁,也叫读锁,用于所有的只读数据操作。共享锁是非独占的,允许多个并发事务读取其锁定的资源。性质1. 多个事务可封锁同一个共享页;2. 任何事务都不能修改该页;3. 通常是该页被读取完毕,S锁立即被释放

427b999b9e210411bc1c48a900122c62.png

排他锁(Exclusive Lock)

X锁,也叫写锁,表示对数据进行写操作。如果一个事务对对象加了排他锁,其他事务就不能再给它加任何锁了。(某个顾客把试衣间从里面反锁了,其他顾客想要使用这个试衣间,就只有等待锁从里面打开了。)

性质1. 仅允许一个事务封锁此页;2. 其他任何事务必须等到X锁被释放才能对该页进行访问;3. X锁一直到事务结束才能被释放

abbc84e81027631879dafc048331d08f.png

更新锁

U锁,在修改操作的初始化阶段用来锁定可能要被修改的资源,这样可以避免使用共享锁造成的死锁现象。

cccf695a260b5872415f6e99fe7c7722.png

性质1. 用来预定要对此页施加X锁,它允许其他事务读,但不允许再施加U锁或X锁;2. 当被读取的页要被更新时,则升级为X锁;3. U锁一直到事务结束时才能被释放。

悲观锁按作用范围划分为:行锁、表锁。

行锁

锁的作用范围是行级别。

表锁

锁的作用范围是整张表。

数据库能够确定那些行需要锁的情况下使用行锁,如果不知道会影响哪些行的时候就会使用表锁。

d6f351d8b1d2a457535ae8e6643b94ef.png

乐观锁(Optimistic Lock)

顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以,不会上锁。但是在更新的时候会判断一下在此期间别人有没有更新这个数据,可以使用版本号等机制。

813c973702e26e6d3337e6eeba27b742.png

乐观锁适用于多读的应用类型,这样可以提高吞吐量,像数据库如果提于write_condition机制的其实都是提供的乐观锁。

乐观锁的实现方式

eb6a1d66b2dfdb40eb217c59feacce78.png

时间戳(使用数据库服务器的时间戳)

eae6dedba12da61f2960d3264f2c8dc3.png

待更新字段

d3fbbc05c11909faddb5c6ea10129a8d.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值