事务(三)

事物的安全问题

丢失更新:指一个事务去修改数据库,另一个事务也修改数据库,最后的那个事务,不管提交还是回滚都会造成前面一个事务的数据更新丢失。

解决办法:悲观锁乐观锁

悲观锁

指事务在一开始就认为丢失更新一定会发生,这是一件很悲观的事情。具体步骤如下:

1)所有事务在执行操作前,先查询一次数据, 查询语句如下:

        select * from student  for update  ;           后面的for update 其实是数据库锁机制 、 一种排他锁。

2) 哪个事务先执行这个语句, 哪个事务就持有了这把锁, 可以查询出来数据, 后面的事务再执行这条语句,不会有任何数据显示,就只能等着。 

3) 一直等到前面的那个事务提交数据后, 后面的事务数据才会出来,那么才可以往下接着操作。

这有点像男生去上卫生间似的, 如果谁先来,谁就可以进去蹲着, 后面来的人,得等着。 只有里面的人出来了,才能进去。 这其实就是 java 中的同步的概念

乐观锁

指从来不会觉得丢失更新会发生。那么它的具体做法是什么呢?

要求程序员在数据库中添加字段,然后在后续更新的时候,对该字段进行判定比对,如果一致才允许更新。例子如下:

1) 数据库表中,额外添加了一个version字段, 用于记录版本, 默认从0 开始, 只要有针对表中数据进行修改的,那么version就+1.

2) 开启A事务, 然后开启B事务 。 

3) A 先执行数据库表操作。 因为以前都没有人修改过。 所以是允许A事务修改数据库的,但是修改完毕,就把version的值变成  1 了 。

4)B事务, 这时候如果想执行修改,那么是不允许修改的。 因为B事务以前是没有查询过数据库内容的,所以它认为数据库版本还是0 。 但是数据库的版本经过A修改,已经是1了。所以这时候不允许修改, 要求其重新查询 。

5) B重新查询后, 将会得到version 为 1的数据,这份数据就是之前A 事务修改的数据了, B 在进行修改,也是在A的基础上修改的。 所以就不会有丢失更新的情况出现了。

乐观锁的机制 ,其实是通过比对版本或者比对字段的方式来实现的, 这与大家在未来的学习中,或者在工作中,使用到的版本控制软件【SVN , GIT】机制是一样的。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值