Oracle 查看表空间的大小及使用情况sql语句(oracle 如何查看表空间)深度揭秘

随心笔谈4个月前发布 admin
201 00
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买

文章摘要

本文介绍了如何通过SQL语句对Oracle数据库的空间资源进行管理与分析,具体包括以下内容: 1. **表空间基本信息**:通过`dba_tablespaces`和`dba_data_files`表获取表空间的名称及大小。2. **物理文件信息**:通过`dba_data_files`表查看表空间的物理文件名称及大小。3. **回滚段信息**:通过`dba_rollback_segs`和`v$rollstat`表获取回滚段的名称、大小及状态。4. **控制文件**:通过`v$controlfile`查看数据库的控制文件信息。5. **日志文件**:通过`v$logfile`获取数据库的日志文件路径及其大小。6. **表空间使用情况**:通过`dba_free_space`表计算各表空间的空闲、使用及占用空间百分比。7. **数据库对象信息**:通过`all_objects`表查询数据库的表、索引、序列等对象的使用情况。8. **数据库版本**:通过`product_component_version`表获取数据库的版本信息。9. **数据库创建信息**:通过`v$database`查看数据库的创建日期、日志归档方式及是否归档。 这些操作有助于用户全面了解数据库的空间管理情况,优化存储资源使用,并进行故障排查与恢复。

–1、查看表空间的名称及大小

SELECT t.tablespace_name, round(SUM(bytes / (1024 * 1024)), 0) ts_size

FROM dba_tablespaces t, dba_data_files d

WHERE t.tablespace_name=d.tablespace_name

GROUP BY t.tablespace_name;

–2、查看表空间物理文件的名称及大小

SELECT tablespace_name,

file_id,

file_name,

round(bytes / (1024 * 1024), 0) total_space

FROM dba_data_files

ORDER BY tablespace_name;

–3、查看回滚段名称及大小

SELECT segment_name,

tablespace_name,

r.status,

(initial_extent / 1024) initialextent,

(next_extent / 1024) nextextent,

max_extents,

v.curext curextent

FROM dba_rollback_segs r, v$rollstat v

WHERE r.segment_id=v.usn(+)

ORDER BY segment_name;

–4、查看控制文件

SELECT NAME FROM v$controlfile;

–5、查看日志文件

SELECT MEMBER FROM v$logfile;

–6、查看表空间的使用情况

SELECT SUM(bytes) / (1024 * 1024) AS free_space, tablespace_name

FROM dba_free_space

GROUP BY tablespace_name;

SELECT a.tablespace_name,

a.bytes total,

b.bytes used,

c.bytes free,

(b.bytes * 100) / a.bytes “% USED “,

(c.bytes * 100) / a.bytes “% FREE ”

FROM sys.sm$ts_avail a, sys.sm$ts_used b, sys.sm$ts_free c

WHERE a.tablespace_name=b.tablespace_name

AND a.tablespace_name=c.tablespace_name;

–7、查看数据库库对象

SELECT owner, object_type, status, COUNT(*) count#

FROM all_objects

GROUP BY owner, object_type, status;

–8、查看数据库的版本 

SELECT version

FROM product_component_version

WHERE substr(product, 1, 6)=’Oracle’;

–9、查看数据库的创建日期和归档方式

SELECT created, log_mode, log_mode FROM v$database;

© 版权声明

相关文章