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; 


切记!切记!切记!
不要直接在生产库上直接操作
展开阅读全文

没有更多推荐了,返回首页