oracle表碎片查询整理过程

 更新时间:2026年01月06日 14:32:12   作者:MrZhou周  
本文通过模拟插入、清理、删除数据,以及表碎片整理,详细记录了表的碎片率和浪费空间的变化,最终通过表碎片整理释放了浪费的空间并降低了高水位,为数据库管理提供了参考

oracle表碎片查询整理

模拟插入数据

create table test as select * from dba_objects;
insert into test select * from test;
insert into test select * from test;
insert into test select * from test;
commit;

收集统计信息

SET TIME ON
exec dbms_stats.gather_table_stats(ownname=>'TEST',tabname=> 'TEST',DEGREE=>2);

查询初始表的碎片率68126

SELECT table_name,
ROUND ( (blocks * 8), 2) "HW_space k",
ROUND ( (num_rows * avg_row_len / 1024), 2) "real_space k",
ROUND ( (blocks * 10 / 100) * 8, 2) "(pctfree) k",
ROUND (
( blocks * 8
- (num_rows * avg_row_len / 1024)
- blocks * 8 * 10 / 100),
2)
"waste_space k"
FROM user_tables
WHERE temporary = 'N' AND TABLE_NAME='TEST'
--and OWNER='TEST'
ORDER BY 5 DESC;

TABLE_NAME HW_space k real_space k (pctfree) k waste_space k
---------- ---------- ------------ ----------- -------------
TEST            89176     68126.08      8917.6      12132.32

第一次模拟清理数据

delete from test where object_type in('SYNONYM','JAVA CLASS');
commit;

再次收集统计信息

SET TIME ON
exec dbms_stats.gather_table_stats(ownname=>'TEST',tabname=> 'TEST',DEGREE=>2);

第一次清理完查询表的碎片率18963

TABLE_NAME HW_space k real_space k (pctfree) k waste_space k
---------- ---------- ------------ ----------- -------------
TEST            89176     18963.03      8917.6      61295.37

第二次模拟删除数据

delete from test where object_type in('VIEW','INDEX','TABLE','TYPE');
commit;

再次收集统计信息

SET TIME ON
exec dbms_stats.gather_table_stats(ownname=>'TEST',tabname=> 'TEST',DEGREE=>2);

第二次清理完查询表的碎片率6199

但是可以看到浪费的空间一直在增加74058.9,高水位一直没有变化89176

TABLE_NAME HW_space k real_space k (pctfree) k waste_space k
---------- ---------- ------------ ----------- -------------
TEST            89176       6199.5      8917.6       74058.9

进行表碎片整理

15:21:46 SQL> alter table test enable row movement;

Table altered.

15:24:52 SQL> alter table test shrink space;

Table altered.

15:25:23 SQL> exec dbms_stats.gather_table_stats(ownname=>'TEST',tabname=> 'TEST',DEGREE=>2);

PL/SQL procedure successfully completed.

15:25:47 SQL> SELECT table_name,
15:25:56   2  ROUND ( (blocks * 8), 2) "HW_space k",
15:25:56   3  ROUND ( (num_rows * avg_row_len / 1024), 2) "real_space k",
15:25:56   4  ROUND ( (blocks * 10 / 100) * 8, 2) "(pctfree) k",
15:25:56   5  ROUND (
15:25:56   6  ( blocks * 8
15:25:56   7  - (num_rows * avg_row_len / 1024)
15:25:56   8  - blocks * 8 * 10 / 100),
2)
15:25:56   9  15:25:56  10  "waste_space k"
FROM user_tables
15:25:56  11  15:25:56  12  WHERE temporary = 'N' AND TABLE_NAME='TEST'
15:25:56  13  --and OWNER='TEST'
15:25:56  14  ORDER BY 5 DESC;

TABLE_NAME HW_space k real_space k (pctfree) k waste_space k
---------- ---------- ------------ ----------- -------------
TEST             7408       6199.5       740.8         467.7

经过以上表碎片整理之后,可以看到表的高水位已经降下来7408,浪费的空间已经得到释放467.7

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • oracle 的表空间实例详解

    oracle 的表空间实例详解

    这篇文章主要介绍了oracle 的表空间实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • ORACLE常见错误代码的分析与解决(三)

    ORACLE常见错误代码的分析与解决(三)

    ORACLE常见错误代码的分析与解决(三)...
    2007-03-03
  • ORACLE应用经验(2)

    ORACLE应用经验(2)

    ORACLE应用经验(2)...
    2007-03-03
  • oracle中的trim函数使用介绍

    oracle中的trim函数使用介绍

    trim一般都是用在删除字符串两边的空格。实际上,trim也可以用来删除字符串两边的指定字符。并且trim指定删除的字符串只能是单个字符
    2014-08-08
  • Oracle数据库物理备份与恢复实战教程

    Oracle数据库物理备份与恢复实战教程

    Oracle RMAN提供了强大而灵活的备份恢复解决方案,通过合理配置和规范操作,可以确保数据库在各种故障场景下的快速恢复,关键是要建立完善的备份策略,并定期验证备份的有效性,本文介绍Oracle数据库物理备份与恢复实战指南,感兴趣的朋友一起看看吧
    2025-11-11
  • Oracle 11g安装错误提示未找到wfmlrsvcapp.ear的解决方法

    Oracle 11g安装错误提示未找到wfmlrsvcapp.ear的解决方法

    这篇文章主要为大家详细介绍了Oracle 11g安装错误提示未找到wfmlrsvcapp.ear的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • Oracle存储过程及调用

    Oracle存储过程及调用

    这篇文章主要介绍了Oracle存储过程及调用,需要的朋友可以参考下
    2017-06-06
  • ORACLE实现字段自增示例说明

    ORACLE实现字段自增示例说明

    如何实现oracle中字段的自增,下面用一个例子来说明,有此需求的各位朋友可以参考下
    2013-11-11
  • Oracle递归查询start with connect by prior的用法

    Oracle递归查询start with connect by prior的用法

    这篇文章主要给大家介绍了关于Oracle递归查询start with connect by prior、的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-02-02
  • ORACLE数据库查看执行计划的方法

    ORACLE数据库查看执行计划的方法

    基于ORACLE的应用系统很多性能问题,是由应用系统SQL性能低劣引起的,所以,SQL的性能优化很重要,分析与优化SQL的性能我们一般通过查看该SQL的执行计划,本文就如何看懂执行计划,以及如何通过分析执行计划对SQL进行优化做相应说明
    2012-05-05

最新评论