美文网首页
Oracle收缩表空间文件多余文件关联解除

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

作者: obaGG | 来源:发表于2018-02-03 10:44 被阅读0次

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

    下文中的 数据库用户名 用 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收缩表空间文件多余文件关联解除

          本文链接:https://www.haomeiwen.com/subject/bzxuzxtx.html