`
azrael6619
  • 浏览: 574643 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

oracle 事务

阅读更多

先了解下以下的名字
       DDL 数据定义语言 -  建立数据库对象
           create /alter/ drop/ truncate
       DML 数据操纵语言 - 数据的查看和维护
           select / insert /delete /update
       TCL 事务控制语言 -  数据是否保存到数据库中
           commit / rollback / savepoint
       DCL 数据控制语言 -- 查看对象的权限

 

事务:

 

  commit;  提交  修改保存到数据库中,结束上一个事务 并且开始一个新的事务
  rollback; 回滚  取消内存中的改动
  savepoint;保存点 分解事务的 把事务变小
       DDL语句 会自动提交以前未提交的事务
       关闭SQLplus工具 也会自动提交未提交的事务的
  事务 -- 就是一个完整的对数据的DML操作

 


一个事务包含一个或多个SQL语句,是逻辑管理的工作单元(原子单元)。
一个事务开始于第一次执行的SQL语句,结束于Commit 或 Rollback 或 DDL语句。
    注意:其中Commit, Rollback是显示的提交事务,而DDL语句是隐式的提交事务的。DDL语句的操作是没有办法回滚的。

 

事务结束的地方有:
  1>. 执行Commit, Rollback, 没有使用savepoint.
  2>. 执行DDL操作如:create , drop, rename, alter
  3>. 断开与Oracle的连接,事务将自动提交。
  4>. 用户进程异常终止,当前事务回滚。
注意:应用程序与Oracle连接的情况,在应用程序终止前必须显示的提交(Commit)或回滚(Rollback)。

 

Commit操作Oracle做了:
  1>. 与UNDO表空间关联的内部事务表记录该事务已经提交,产生唯一的系统交易号(SCN)保存到该表中。
  2>. LGWR进程将SGA中的重做日志写入redo log文件,当然也要写SCN到重做日志文件。
  3>. Oracle释放锁定表中的行。
  4>. Oracle设置该事务完成。

  注意:Commit操作前的改变数据(保存在SGA)不会马上写到数据文件中。这样做的目的也是为了数据库更高效。从开发人员的角度想想也是这样的,这样可以减少很多小事务的多次写磁盘的。

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics