会员控制台 会员登陆 会员注册 最后更新 高级搜索 会员投稿 退出登陆
设为首页
收藏本站
留言给我
  首页 | 操作系统类 | 程序设计类 | 数据库类 | 应用服务类 | 网络及硬件类 | 其他技术 | GBunix论坛
操作系统类
程序设计类
数据库类
应用服务类
网络及硬件类
其他技术
Unix中文 / 数据库类 / Oracle / 关于ROLLBACK SEGMENT
关于ROLLBACK SEGMENT
2004-07-14          点击:
关于ROLLBACK SEGMENT

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

通常,我们需要(并发ORACLE用户连接数/4 ) 个rollback segment,一般用private类型, 最大的个数为50。

创建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
set transction use rollback_segment rte;
update table_name set filed_name=...... where ...... ;
commit;

了解更多详情,参与讨论,请进入GBUNIX论坛

http://www.gbunix.com/bbs/index.php
责任编辑: trotter
发表评论 查看评论 加入收藏 Email给朋友 打印本文
给该文章评分
1 2 3 4 5 6 7 8 9 10
平均得分 0, 共 0 人评分
1 2 3 4 5 6 7 8 9 10
发表评论
标题:
内容:
声明:本站资讯均来自互联网,所有文章版权归原作者和出版者所有,如涉及版权问题,请来信告知!
Copyright © 2002-2004 GBunix.com. All rights reserved.