Oracle笔记-查看表已使用空间&最大空间

目前以Oracle18c为例,主要是查这个表USER_SEGMENTS。

在 Oracle 18c 数据库中,USER_SEGMENTS 是一个系统表,用于存储当前用户(当前会话)拥有的所有段的信息。段是 Oracle 中分配存储空间的逻辑单位,用于存储表、索引、分区、簇等对象的数据。

USER_SEGMENTS 表包含以下列:

  • SEGMENT_NAME: 段的名称。
  • SEGMENT_TYPE: 段的类型,可以是表(TABLE)、索引(INDEX)、簇(CLUSTER)、分区(PARTITION)等。
  • TABLESPACE_NAME: 段所属的表空间名称。
  • BYTES: 段的大小(以字节为单位)。
  • BLOCKS: 段占用的数据块数。
  • EXTENTS: 段的扩展数。
  • INITIAL_EXTENT: 段的初始扩展大小(以字节为单位)。
  • NEXT_EXTENT: 段的下一个扩展大小(以字节为单位)。
  • MIN_EXTENTS: 段的最小扩展数。
  • MAX_EXTENTS: 段的最大扩展数。
  • INCREMENT_BY: 段按多少单位增加大小。
  • STATUS: 段的状态(有效、无效、上锁等)。

通过查询 USER_SEGMENTS 表,你可以获取当前用户所有段的信息,如表名、大小、扩展信息等。例如,可以使用以下 SQL 查询获取当前用户的所有表和索引的信息:

sql 复制代码
SELECT SEGMENT_NAME, SEGMENT_TYPE, BYTES, BLOCKS
FROM USER_SEGMENTS
WHERE SEGMENT_TYPE IN ('TABLE', 'INDEX');

这将返回当前用户拥有的所有表和索引的名称、类型、大小和占用的块数。

比如查表目前的空间大小和大小

sql 复制代码
select sum(BYTES) / 1024 / 1024 as SIZE_M, sum(MAX_SIZE) / 1024 / 1024 as MAX_SIZE_M from user_segments where segment_name = 'XXXX'

查看他的spaceName

sql 复制代码
select TABLESPACE_NAME from user_segments where segment_name = 'XXXX'

查看这个space_name是否能自增

sql 复制代码
select file_name,autoextensible,increment_by from dba_data_files where tablespace_name = 'USERS'; 

根据查询结果中的 AUTOEXTENSIBLE 列的值来判断是否允许自动增加段的大小:

  • 如果 AUTOEXTENSIBLE 的值为 'YES',表示允许自动扩展,当表的数据超过当前段大小时,数据库会自动增加段的大小。
  • 如果 AUTOEXTENSIBLE 的值为 'NO',表示不允许自动扩展,达到段的最大限制后将无法自动增加段的大小。
相关推荐
zhangrelay3 分钟前
云课实践速通系列-基础篇汇总-必修-通识基础和专业基础-2026--工科--自动化、电气、机器人、测控等
linux·笔记·单片机·学习·ubuntu·机器人·自动化
05候补工程师10 分钟前
【编译原理】自顶向下语法分析深度解析:从 LL(1) 文法判定、改写到预测分析表
经验分享·笔记·考研·自然语言处理
czlczl2002092512 分钟前
MAX()和MIN()优化
数据库·mysql·性能优化
消失的旧时光-19431 小时前
SQL 第一篇:CRUD 实战,从 user 表开始写接口
数据库·sql·mysql
小江的记录本2 小时前
【Kafka核心】Kafka高性能的四大核心支柱:零拷贝、批量发送、页缓存、压缩
java·数据库·分布式·后端·缓存·kafka·rabbitmq
.小小陈.2 小时前
MySQL 核心基础:数据类型与表约束全解析
数据库·mysql
ErizJ2 小时前
Linux|学习笔记
linux·笔记·学习
KmSH8umpK2 小时前
Redis分布式锁进阶第十二篇
数据库·redis·分布式
hERS EOUS2 小时前
MySQL 函数
数据库·mysql
gQ85v10Db2 小时前
Redis分布式锁进阶第十六篇:番外高阶避坑篇 + 隐性埋点锁故障深挖 + 疑难杂症终极兜底方案
数据库·redis·分布式