Oracle事务管理
一个事务包含一个或多个SQL语句,是逻辑管理的工作单元(原子单元)。
一个事务开始于第一次执行的SQL语句,结束于Commit 或 Rollback 或 DDL语句。
注意:其中Commit, Rollback是显示的提交事务,而DDL语句是隐式的提交事务的。DDL语句的操作是
没有办法回滚的。
##########################
eg:
SQL> create table a ( i int);
表已创建。
SQL> insert into a values(1);
已创建 1 行。
SQL> create table b ( i int);
表已创建。
SQL> rollback;
回退已完成。
SQL> select * from a;
I
----------
1
#############################
在执行create table b 的时候事务就已经提交了。
事务结束的地方有:
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)不会马上写到数据文件中。这样做的目的也是为了数据
库更高效。从开发人员的角度想想也是这样的,这样可以减少很多小事务的多次写磁盘的。
Oracle 10.2中与事务有关的:
commit work write immediate wait; --是Oracle默认的设置。
alter system set commit_write = nowait; --改变系统提交方式
alter session set commit_write = nowait; --改变会话提交方式
##############################
提交一个事务 eg:
SQL> commit work;
提交完成。
SQL> show autocommit;
autocommit OFF
SQL> create table t0(testcol number);
表已创建。
SQL> insert into t0 values(1);
已创建 1 行。
SQL> commit;
提交完成。
SQL> select * from t0;
TESTCOL
----------
1
SQL> insert into t0 values(2);
已创建 1 行。
SQL> commit work;
提交完成。
SQL> select * from t0;
TESTCOL
----------
1
2
####################################
commit comment eg:
see more :
阅读(8541) | 评论(0) | 转发(0) |