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 ;