温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Oracle中怎么使用sql语句查看表空间的大小

发布时间:2021-07-24 16:25:05 来源:亿速云 阅读:153 作者:Leah 栏目:数据库

这期内容当中小编将会给大家带来有关Oracle中怎么使用sql语句查看表空间的大小,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

  Oracle 查看表空间的大小的方法1.代码如下:

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

  Oracle 查看表空间的大小的方法2.代码如下:

  --1G=1024MB

  --1M=1024KB

  --1K=1024Bytes

  --1M=11048576Bytes

  --1G=1024*11048576Bytes=11313741824Bytes

  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

上述就是小编为大家分享的Oracle中怎么使用sql语句查看表空间的大小了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI