oracle事务管理-凯发app官方网站

凯发app官方网站-凯发k8官网下载客户端中心 | | 凯发app官方网站-凯发k8官网下载客户端中心
  • 博客访问: 3976925
  • 博文数量: 536
  • 博客积分: 10470
  • 博客等级: 上将
  • 技术积分: 4825
  • 用 户 组: 普通用户
  • 注册时间: 2006-05-26 14:08
文章分类

全部博文(536)

文章存档

2024年(3)

2021年(1)

2019年(1)

2017年(1)

2016年(2)

2013年(2)

2012年(10)

2011年(43)

2010年(10)

2009年(17)

2008年(121)

2007年(252)

2006年(73)

相关博文
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·
  • ·

分类: oracle

2006-11-23 13:21:56

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 :

阅读(8508) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
")); function link(t){ var href= $(t).attr('href'); href ="?url=" encodeuricomponent(location.href); $(t).attr('href',href); //setcookie("returnouturl", location.href, 60, "/"); }
网站地图