昨晚因为做了一个大批量的删除,用的delete。大约用了6个小时,导致了回滚段自动扩展到将近30个G。(以后记着,做大批量删除的时候,一定要用脚本实现,分批量提交事务。那样就不会占用太多的UNDO表空间了!)
从网上搜了一个普遍的方法,更换新的UNDO表空间,然后删除原来的UNDO表空间,释放出磁盘容量。
具体方法如下:(参考网上的资料)
1、查询回滚段信息:状态为ONLINE,当前UNDO表空间为undotbs1
SQL>select segment_name, owner, tablespace_name,
status from dba_rollback_segs;
SEGMENT_NAME
------------------------------ ------
------------------------------
----------------
SYSTEM
_SYSSMU1$
_SYSSMU2$
_SYSSMU3$
_SYSSMU4$
_SYSSMU5$
_SYSSMU6$
_SYSSMU7$
_SYSSMU8$
_SYSSMU9$
_SYSSMU10$
11 rows selected.
2、创建一个新的回滚段:
SQL>CREATE UNDO
注:UNDOTBS2为新建回滚段名称,可自拟。'd:/oracle/oradata/oradev/UNDOTBS2.dbf'
是表空间数据文件地址,可根据情况设定。
3、切换回滚段:
SQL> alter system set undo_tablespace=undotbs2 scope=both;
这样系统默认UNDO表空间就是新建的undotbs2了。
4、重启数据库后,即可删除原来的回滚段,这样就能释放磁盘空间了。
SQL> drop rollback segment
undotbs1;
5、对回滚段的大小,可以根据情况进行调整,也可以改为自动扩展。
下面是网友提供的一个小技巧:
调小了回滚段后,在imp导入数据时,提示回滚段无法扩展的错误。
解决方法:在imp时,加入参数 commit=y,直接提交,避免占用大回滚段。