数据库多个事物的并发问题

数据库并发操作存在的异常情况脏读

设置数据库的隔离级别:        

  setTRANSACTION ISOLATION LEVEL  READUNCOMMITTED<span style="font-size:14px">业务情景:</span>

             张三准备用ATM机向其北京招行的帐户汇1000块钱,在汇之前先用其智能手机的手机银行客户端查询到其北京账户还剩100,接着他用ATM机向其北京帐户打过去1000,在提示确认提交时,他又用手机查看了一下其帐户余额竟然为1100

 

数据库并发操作存在的异常情况不可重复读

设置数据库的隔离级别:

setTRANSACTION ISOLATION LEVEL  READCOMMITTED ;<span style="font-size:14px">业务情景:</span>

             张三用其智能手机的手机银行客户端查询其招行帐户余额为100元,他没有马上退出,去做了一会别的事,在此过程中他老婆在一个ATM机上向其帐户上汇入了1000元,他回来后又刷新了一下余额,竟然为1100元。

 

数据库并发操作存在的异常情况——幻读(Magic read)

设置数据库的隔离级别 

setTRANSACTION ISOLATION LEVEL  REPEATABLEREAD;<span style="font-size:14px">业务情景:</span>

         张三用其智能手机的手机银行客户端查询其招行帐户余额为300元,他准备用其中的200去抢购一个商品,在他没付款之前他的老婆取走100元,他再次查看了一下余额,还是300元,他花了200支付了商品,在支付完后,他再次查了一下余额,竟然发现账户里一毛钱都没有啦!

 

 

数据库并发操作存在的情况— 不能并发

设置数据库的隔离级别:

<span style="color:#000000">setTRANSACTION ISOLATION LEVEL SERIALIZABLE;</span>

业务情景:

             张三用其智能手机的手机银行客户端查询其招行帐户余额为99.9元,但他需要100元才能支付抢购,他QQ告知老婆在线等待,他老婆立马找到一个ATM机准备向其帐户上汇入了100元,但钱就是汇不进去。

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值