ORACLE解决高水位线问题
--方法一.
ALTER TABLE table_name MOVE ;--对表重建
ANALYZE TABLE table_name COMPUTE STATISTICS ;--统计分析
--方法二.
ALTER TABLE table_name ENABLE ROW MOVEMENT;--激活行迁移
ALTER TABLE table_name SHRINK SPACE;--激活表收缩
ANALYZE TABLE table_name COMPUTE STATISTICS ;--统计分析
弊端:如果是分区表,激活后,表数据会因为更新分区字段更新磁盘物理位置(ROWID);
方法三:
CREATE TABLE table_name_1 AS SELECT * FROM table_name;
TRUNCATE TABLE table_name;
INSERT INTO table_name SELECT * FROM table_name_1;
弊端:麻烦,耗时
方法四:
新建一个临时表,把数据复制到临时表,然后把源表drop掉,再把临时表重新命名为源表的名字。
弊端,主键.索引等依托于此表的对象需要重建
校验方法:
通过分析比对表块删除数据前后占用变化.
SELECT num_rows ,blocks, empty_blocks FROM dba_tables WHERE owner='SDBMGR' AND table_name ='TABLE_NAME';
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341