Chinaunix首页 | 论坛 | 博客
  • 博客访问: 554639
  • 博文数量: 855
  • 博客积分: 40000
  • 博客等级: 大将
  • 技术积分: 5005
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-16 19:08
文章分类

全部博文(855)

文章存档

2011年(1)

2008年(854)

我的朋友

分类:

2008-10-16 19:26:17


  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;
  
【责编:admin】

--------------------next---------------------

阅读(385) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~