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; 


切记!切记!切记!
不要直接在生产库上直接操作
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值