加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

Oracle数据文件碎片整理

发布时间:2021-01-10 09:46:08 所属栏目:站长百科 来源:网络整理
导读:在我的体系中,永世数据与一些姑且数据(如日记)分隔.这是通过将日记表(用户界说的措施日记,不与体系日记夹杂)存储在与主处事器差异的表空间中来完成的. 因此有两个表空间MAIN和LOG.每个表空间都有一个数据文件.两个数据文件maxsize都配置为4GB,初始巨细为8MB,

在我的体系中,永世数据与一些姑且数据(如日记)分隔.这是通过将日记表(用户界说的措施日记,不与体系日记夹杂)存储在与主处事器差异的表空间中来完成的.

因此有两个表空间MAIN和LOG.每个表空间都有一个数据文件.两个数据文件maxsize都配置为4GB,初始巨细为8MB,而且它们在接下来的8MB上自动扩展.

因为我行使oracle的快递版,我必要它们总和不高出4GB.

当我必要减小LOG数据文件的巨细以开释一些空间以获取须要的数据时,偶然会产生这种环境.

此刻我这样做:

truncate table schema_name.log_table;
alter database datafile '/path/to/the/log/datafile/log1.dbf' resize 128M;

它的事变道理,由于truncate挣脱了数据文件中的全部信息.

可是假如我碰着必要从MAIN中开释一些LOG表空间巨细的环境怎么办呢.我在哪里截断了几个表(可能我知道数据文件中有许多可用空间,它已经分派但没有被数据占用,之前用于某些操纵),此刻必要对MAIN表空间的数据文件举办碎片清算以减小它的巨细.没有碎片清算我获得一个破例:

ORA-03297: file contains used data beyond requested RESIZE value

以是我能以某种方法对数据文件执行碎片清算操纵吗?

办理要领

根基上有三个级此外空间分派必要思量.

>表和索引段中的行行使的空间.删除行凡是足觉得该段中的新数据开释空间,但这不会开释该段在数据文件中占用的空间.
>分段占用数据文件中的空间.截断表默认会缩小段,可能假如段中有大量可用空间,则可以移动表和/或重建索引.这也将改变数据文件中段的位置,这也许与…相干.
>数据文件在存储上行使的空间.可以缩小文件,但文件中段的位置很是重要.您只能紧缩到最后一个细分的末端.假如您偶然刻和资源,则可以将段移动/重建到差异的表空间,然后紧缩数据文件并再次移动/重建它们.

这(3)是您面对的题目.完备的移动和重建不是独一的选择……您可以导出全部内容或实行仅移动/重建数据文件末端的段,但这更伟大.假如可以,请停止行使它.

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读