oracle数据库笔记1commitrollbacksavepoint

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 ;
          

  

原文地址:https://www.cnblogs.com/wust221/p/commit.html