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 ;