数据库的事务处理

对于数据表的操作,很明显查询是比更新操作更安全,因为更新操作有可能会出现错误,以导致没有按照既定的要求正确完成操作

但是在很多时候,更新有可能会有多条指令共同完成,例如:银行转账
从A转5000到B的账户:
1.判断A的账户是否有5000
2.判断B账户是否存在且状态是否正常
3.从A账户中扣除5000
4.向B账户中增加5000
5.扣除相应的手续费

以上的5个操作是一个整体,可以理解为一个完整的业务,如果这之中第三点出错了,那么其它操作呢?所有的操作都应该不再执行,并且回归到最原始的状态,而这一操作流程就是事务的操作
所有的事务操作都是针对每一个session进行的,在oracle数据库之中,把每一个连接到数据库上的用户都称为一个session,每一个session之间都彼此独立,不会含有任何的通讯,而每一个session独享自己的事务控制,而事务控制之中主要使用两个命令:

1. 事务的回滚:ROLLBACK,更新操作回到原点
2. 事务的提交:COMMIT,真正的发出更新的操作,一旦提交之后无法回滚
但是这样也会出现问题,例如:某一个session在更新后并没有进行提交事务,这时候其它session是无法进行更新的,必须等待之前的session提交后才可以更新完成

下面示范:
打开两个session ,用户都为scott

</

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值