关于ROLLBACK SEGMENT

王朝other·作者佚名  2006-01-09
宽屏版  字体: |||超大  

rollback segment是ORACLE里一种很特殊的数据对象,它处理事务的回滚操作。

通常,我们需要(并发ORACLE用户连接数/4 ) 个rollback segment,一般用private类型.

最大的个数可以查看数据库参数。

SQL> select name,value from v$parameter where instr(name,'rollback')>0;

创建r01,r02,r03,r04以外的rollback segment语法:

create rollback segment r05 tablespace rbs storage (initial 128k next 128k minextents 20 );

alter rollback segment r05 online;

...... ......

rollback segemt 缺省的存储参数:pctincrease 0 minextents 偶数

maxextent跟数据库的块大小有关

2K 121

4K 249

8K 505

针对某个特定的大事务操作,如update大量数据时,可以建一个大的rollback segment

如:

create rollback segment rte tablespace rbs storage (initial 5M next 5M minextents 20);

alter rollback segment rte online;

改数据库参数文件 initoraid.ora

rollback_segments = (r01, r02, r03, r04,r05,r06,r07,r08,r09,r10,r11,r12,rte)

重启数据库,新建的rollback_segment才生效

把大事务操作指给大的回滚段rte

commit; set transaction use rollback segment rte;

update table_name set field_name=...... where ...... ;

commit;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有