[Oracle Transaction]Oracle数据库事务

  本人的Blog更新: http://www.iwllsea.com/default.asp?cateID=9,涉及更多Oracle文章,希望对大家有所帮助。
 
1.0摘要
本篇主要介绍什么是事务以及对数据库操作时如何控制事务。
 
事务是作为单个逻辑工作单元执行的一系列操作。一个逻辑工作单元必须有四个属性,称为 ACID (原子性、一致性、隔离性和持久性)属性,只有这样才能成为一个事务:
原子性:事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。
一致性:事务在完成时,必须使所有的数据都保持一致状态。在相关数据库中,所有规则都必须应用于事务的修改,以保持所有数据的完整性。事务结束时,所有的内部数据结构(如 B 树索引或双向链表)都必须是正确的。
隔离性:由并发事务所作的修改必须与任何其它并发事务所作的修改隔离。事务查看数据时数据所处的状态,要么是另一并发事务修改它之前的状态,要么是另一事务修改它之后的状态,事务不会查看中间状态的数据。这称为可串行性,因为它能够重新装载起始数据,并且重播一系列事务,以使数据结束时的状态与原始事务执行的状态相同。
持久性:事务完成之后,它对于系统的影响是永久性的。该修改即使出现系统故障也将一直保持。
所以,当我们需要进行事务处理时,一定要做好事务划分,即哪些对数据库的操作均完成后才能作为一个事务。
 
oracle没有“开始事务”的语句,事务隐式地开始于第一条修改数据的语句,并以commit或rollback语句显式的结束事务。一条语句要么完全执行,要么完全回滚,一条语句的失败不能使它前面执行的语句自动回滚。
事务控制语句:commit,rollback,savepoint,rollback to <savepoint>
set transaction:设置不同的事物属性,例如隔离等级和是否只读或可读写,也可以使用此语句来指示事务使用某个特定的回滚段。
COMMIT 是事务提交命令。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值