oracle数据库----笔记1---commit----rollback----savepoint

SQL控制功能,反映在两个方面:
 
1.  控制用户对数据的存取能力
2. 控制数据的完整性,包括对数据改变发生时刻及效果的控制等
 
commit , rollback and savepoint
 
在ORACLE系统中,为了维护数据库数据的一致性,为每个用户分别设置了一个工作区,
所有增、删、改操作都是在工作区中进行的,在内存工作区中进行这些操作的数据,
在执行COMMIT命令之前,对数据库中的数据无任何影响。
 
在工作区中所作的增、删、改操作,可向数据库提交或
 取消。通常称事务提交和取消。
 
一个事务是由一组逻辑上相关的SQL语句所组成。它被
 用来完成某一特定任务,ORACLE 把事务作为处理的逻辑单位。
事务提交是把一个事务对数据库所产生的变更写入
 数据库,使其他用户可见。
事务回退就是取消当前事务对
  数据库所做的变更,使数据库将恢复事务开始时的状态
 
事务提交有三种方式:
( 1)SQL>commit ;
(2)隐式执行commit命令
        在某些SQL命令执行后,系统会自动执行提交命令。
        如: alter, create, exit, drop,quit,  grant等命令以及退出SQL*PLUS操作
 (3)在SQL*PLUS环境中,用set命令设置一个自动提交开关:
     SQL>set  autocommit  on
         SQL>set  autocommit   off
 
事务回退  
 
 
事务回退就是取消当前事务对数据库所做的变更。
使数据库状态保持上次最后提交的状态
 SQL>ROLLBACK。
 
注意:一旦执行提交成功,ROLLBACK命令就执行无效
 
3.保存点命令(SAVEPOINT)
 
用来实现部分事务级回滚。(通过在事务内部设置保留点)
 
保存点命令用于标识事务中的一个点,以后可回退到该点。
  
保留点与ROLLBACK命令一起使用,可回退当前事务的一
部分。
 
 
保留点在交互式程序中有用,为程序建立和命名一个中间步。
当在程序执行过程中产生一个错误时,利用保留点不必重作每一个语句。
各保留点的名字在一个事务内必须不同
 
操作者执行该命令时无需任何特权
 
程序文件中有如下命令组
 ①  update   emp
 
     set  sal=2000
   
     where  ename=’BLAKE’;
     SAVEPOINT  BLAKE_Sal;
  
 ②  update  emp
 
     set   sal=1500
  
     where  ename=’CLARK’;
  
    SAVEPOINT  CLARK_SAL;
   
 ③   select  sum(sal)  from   emp ;
     
     ROLLBACK  TO  BLACK_Sal;
  
④ commit ;
 
   Select * from emp ;
          

  

posted @ 2013-05-08 01:24  wust小吴  阅读(538)  评论(0)    收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示