ORACLE数据库巡检SQL脚本--1、检查表空间使用情况

查询各表空间的管理属性、空间总量、空闲量及使用率,用于巡检表空间是否存在空间不足风险。

一、SQL脚本

sql 复制代码
--检查表空间使用情况
SELECT B.TABLESPACE_NAME          TABLESPACE,
       A.EXTENT_MANAGEMENT        EXT_MGT, -- 表空间的区管理方式(LOCAL/LOCAL AUTOALLOCATE等)
       A.SEGMENT_SPACE_MANAGEMENT SEG_MGT, -- 表空间的段管理方式(AUTO/MANUAL)
       A.STATUS                   STATUS, -- 表空间状态(ONLINE/READ ONLY等)
       A.LOGGING                  LOGGING, -- 表空间日志模式(LOGGING/NOLOGGING)
       B.TOTAL                    TOTAL, -- 表空间总大小(GB)
       B.FREE                     FREE, -- 表空间空闲大小(GB)
       B.USED_PCT                 USED_PCT -- 表空间使用率(%)
  FROM DBA_TABLESPACES A,
       (SELECT D.TABLESPACE_NAME,
               ROUND(D.SUMBYTES / 1024 / 1024 / 1024, 2) || 'GB' TOTAL, -- 计算总空间(转GB,保留2位小数)
               ROUND(DECODE(F.SUMBYTES, NULL, 0, F.SUMBYTES) / 1024 / 1024 / 1024, 2) || 'GB' FREE, -- 计算空闲空间(空值处理为0)
               ROUND((D.SUMBYTES - DECODE(F.SUMBYTES, NULL, 0, F.SUMBYTES)) * 100 / D.SUMBYTES, 2) || '%' USED_PCT -- 计算使用率
          FROM (SELECT TABLESPACE_NAME, SUM(BYTES) SUMBYTES FROM DBA_FREE_SPACE GROUP BY TABLESPACE_NAME) F,
               (SELECT TABLESPACE_NAME, SUM(BYTES) SUMBYTES FROM DBA_DATA_FILES GROUP BY TABLESPACE_NAME) D
         WHERE F.TABLESPACE_NAME(+) = D.TABLESPACE_NAME -- 外连接,确保包含无空闲空间的表空间
         ORDER BY D.TABLESPACE_NAME) B
 WHERE A.TABLESPACE_NAME = B.TABLESPACE_NAME;

二、脚本说明

该SQL会返回以下关键信息,用于表空间巡检:

  1. TABLESPACE:表空间名称;
  2. EXT_MGT:表空间的区管理方式 (如LOCAL,表示本地管理,是Oracle推荐的方式);
  3. SEG_MGT:表空间的段管理方式 (如AUTO,表示自动段空间管理);
  4. STATUS:表空间状态(正常应为ONLINE);
  5. LOGGING:表空间日志模式(正常应为LOGGING,确保数据可恢复);
  6. TOTAL:表空间总大小(单位:GB);
  7. FREE:表空间空闲大小(单位:GB);
  8. USED_PCT:表空间使用率(单位:%,通常使用率超过90%需预警)。

三、注意事项

  • 若某表空间的USED_PCT接近或超过90%,需及时扩展表空间(添加数据文件或扩展现有数据文件);
  • 若表空间状态为OFFLINE/READ ONLY,需排查是否为异常状态;
  • EXT_MGTDICTIONARY(字典管理),建议迁移为LOCAL管理(Oracle 10g后推荐本地管理)。
相关推荐
廿一夏8 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim9 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室10 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)10 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU11 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng12 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿13 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-13 小时前
Redis 命令
数据库·redis·缓存
小江的记录本13 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`14 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存