方法二:新建UNDO表空间,替换原来的UNDO表空间
1. 创建一个新的小的undo表空间
执行
CREATE UNDO TABLESPACE UNDOTBS1
DATAFILE 'E:oradataUNDOTBS01.DBF'
SIZE 100M REUSE AUTOEXTEND ON;
其中 'E:oradataUNDOTBS01.DBF' 为表空间文件想要存储的位置
100M 表示新的表空间的初始大小。
2. 设置新的表空间为系统的Undo表空间
执行
ALTER SYSTEM SET UNDO_TABLESPACE=UNDOTBS1;
3. 重启数据库
可以使用sys用户,从sqlplus登录,执行startup force命令,强制重启
4. 删除旧的Undo表空间
依旧使用sys用户登录,执行
DROP TABLESPACE UNDOTBS01 INCLUDING CONTENTS AND DATAFILES;
至此,UNDOTBS01.DBF文件缩小完毕,如果想要还原原来的表空间名称,重新执行方法二即可。