Oracle收缩表空间文件多余文件关联解除

在平时的工作中,有时候把数据库的数据部分删除掉(比如测试库不需要太多数据),但是删除数据之后,表空间并没有自动收缩,还是会占用很多的硬盘空间。下文帮助大家解决这个困扰。

下文中的 数据库用户名 用 dbName代替;密码用 dbPass 代替; 文件路径用 fileSource代替;表空间名用 tablespaceName 代替;

--给用户分配权限

SQL>grant connect,resource,dba to dbName;

--创建备份路径

SQL>create directory dump as 'fileSource';

--导出备份(系统命令行执行)

expdp dbName/dbPass dumpfile=backup.dmp directory=dump logfile=backup.log job_name=exp_backup;

--表空间离线

SQL>alter tablespace tablespaceName offline;

--删除表空间及文件,但不会删除用户(用户保留,我们的目的只是操作表空间文件)

SQL>drop tablespace tablespaceName including contents and datafiles;

--创建新的表空间及表空间文件

SQL>CREATE TABLESPACE tablespaceName DATAFILE 'fileSource/XXX.dbf' size 256M autoextend on next 256M maxsize unlimited;

--修改用户默认表空间(原来的用户直接指向新的表空间)

SQL>alter user dbName default tablespace tablespaceName;

--导入备份(系统命令行执行)

impdp dbName/dbPass dumpfile=backup.dmp directory=dump SCHEMAS=dbName logfile=backup.log job_name=imp_backup;

切记!切记!切记!

不要直接在生产库上直接操作

反正也不会有人打赏我

你可能感兴趣的:(Oracle收缩表空间文件多余文件关联解除)