在平时的工作中,有时候把数据库的数据部分删除掉(比如测试库不需要太多数据),但是删除数据之后,表空间并没有自动收缩,还是会占用很多的硬盘空间。下文帮助大家解决这个困扰。
下文中的 数据库用户名 用 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;
切记!切记!切记!
不要直接在生产库上直接操作
反正也不会有人打赏我