ORACLE数据库巡检SQL脚本--22、检查碎片程度最高的业务表

该脚本用于检查Oracle数据库中碎片程度最高的业务表(段对象),通过统计段的扩展次数(EXTENTS)定位存储碎片最严重的表,是存储优化、性能调优中识别存储结构瓶颈的常用工具。

一、sql脚本

sql 复制代码
SELECT SEGMENT_NAME TABLE_NAME, COUNT(*) EXTENTS
  FROM DBA_SEGMENTS
 WHERE OWNER NOT IN ('SYS', 'SYSTEM')
 GROUP BY SEGMENT_NAME
HAVING COUNT(*) = (SELECT MAX(COUNT(*)) FROM DBA_SEGMENTS GROUP BY SEGMENT_NAME);

二、脚本说明

1、使用场景

  • 日常存储巡检:定期检查业务表的存储碎片程度,提前发现存储结构隐患;
  • 性能优化:当表查询性能下降、IO负载异常时,定位碎片导致的性能瓶颈;
  • 存储规划:分析碎片生成模式,为表空间扩容、存储架构优化提供依据;
  • 故障排查 :段扩展失败(ORA-01631)时,检查是否因碎片过多导致扩展次数耗尽。

2、字段说明

字段名 说明
TABLE_NAME 碎片程度最高的业务表名称(原字段SEGMENT_NAME的别名)
EXTENTS 该表的存储扩展次数,扩展次数越多代表存储碎片越严重

三、注意事项

查询结果有记录返回即表示存在问题:返回的表是数据库中扩展次数最多的业务表,说明其存储碎片程度已达到最高级别,若不处理会持续影响性能与存储稳定性。

四、补充说明

1、异常的影响

  • 查询性能下降:碎片导致表数据块分散存储,读取时需要多次IO操作,增加查询耗时;
  • IO负载加剧:分散的数据块读取会持续占用磁盘IO资源,引发其他业务SQL性能恶化;
  • 扩展失败风险 :当扩展次数达到MAX_EXTENTS时,表无法继续扩展,导致插入、更新等操作失败(如ORA-01631错误);
  • 存储资源浪费:碎片产生的空闲空间无法被有效利用,降低存储利用率。

2、处理建议

  1. 重组表结构(核心优化)

    sql 复制代码
    -- 重组表,消除碎片(需在业务低峰期执行)
    ALTER TABLE 表名 MOVE TABLESPACE 目标表空间;
    -- 重建表上的索引(重组表后索引会失效)
    ALTER INDEX 索引名 REBUILD TABLESPACE 目标表空间;
  2. 分区表改造:对大表按时间/业务维度分区,减少单表的扩展次数与碎片生成;

  3. 开启自动段空间管理(ASSM) :将表空间设置为ASSM模式,Oracle会自动优化段的扩展与碎片回收:

    sql 复制代码
    CREATE TABLESPACE 表空间名 DATAFILE '/路径/文件名.dbf' SIZE 10G AUTOEXTEND ON NEXT 1G MAXSIZE UNLIMITED SEGMENT SPACE MANAGEMENT AUTO;
  4. 定期监控与维护:将碎片检查加入日常巡检计划,对扩展次数超过阈值(如1000次)的表提前重组;

  5. 调整存储参数 :将表的MAX_EXTENTS设置为UNLIMITED,避免扩展次数耗尽导致的业务中断。

相关推荐
峥无8 分钟前
MySQL DML 操作(CRUD)总结
数据库·mysql
数据库小学妹43 分钟前
SQL Server数据库同步工具怎么选?6款方案对比+信创迁移避坑清单
数据库·经验分享·sqlserver·dba
不剪发的Tony老师1 小时前
国产数据库之GaussDB:固若金汤
数据库·gaussdb
雨辰AI1 小时前
生产级实测:SpringBoot3 + 达梦数据库接口从 200ms 优化至 20ms 完整调优指南
java·数据库·spring boot·后端·政务
凡人叶枫2 小时前
Effective C++ 条款39:明智而审慎地使用 private 继承
java·数据库·c++·嵌入式开发
基德爆肝c语言2 小时前
MySQL表的操作
前端·数据库·mysql
TDengine (老段)2 小时前
TDengine 连接算子 — Inner/Outer/ASOF/Window Join 的实现与使用
大数据·数据库·物联网·哈希算法·时序数据库·tdengine·涛思数据
Keano Reurink3 小时前
搜索API与GSC数据对比:发现数据盲区
数据库·python·数据挖掘
shushangyun_3 小时前
汽车服务行业B2B平台+AI解决方案哪家专业:2026年最新测评
java·运维·网络·数据库·人工智能·汽车
大黄说说3 小时前
深入理解 Go 协程 Goroutine:并发编程的核心精髓
java·数据库·python