暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 表空间相关

Oracle自学进阶 2021-02-06
694

前段时间有一友人问:怎么查看数据库表空间的相关信息?(而我又以前恰好因项目需求在自己的本地制造了数据量为5亿的个人的相关信息用于测试info从Oracle数据库到TD数据库的数据抽取速率。而在制造数据时需要监控表空间的大小及使用率,毕竟如果出现因随着数据的增多而导致表空间不足就比较尴尬了。)

所以整理了一些sql:

--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;

--10、查看表空间使用情况

SELECT a.tablespace_name "表空间名",

       total "表空间大小",

       free "表空间剩余大小",

       (total - free) "表空间使用大小",

       total / (1024 * 1024 * 1024) "表空间大小(G)",

       free / (1024 * 1024 * 1024) "表空间剩余大小(G)",

       (total - free) / (1024 * 1024 * 1024) "表空间使用大小(G)",

       round((total - free) / total, 4) * 100 "使用率 %"

  FROM (SELECT tablespace_name, SUM(bytes) free

          FROM dba_free_space

         GROUP BY tablespace_name) a,

       (SELECT tablespace_name, SUM(bytes) total

          FROM dba_data_files

         GROUP BY tablespace_name) b

 WHERE a.tablespace_name = b.tablespace_name

 ;


 


最后修改时间:2021-02-06 18:33:50
文章转载自Oracle自学进阶,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论