oracle表空间扩容

第一步:查看表空间的名字及文件所在位置:

  select tablespace_name, file_id, file_name, round(bytes/(1024*1024),0) total_space from dba_data_files order by tablespace_name

  另一语句:

 

  SELECT 

    a.tablespace_name "表空间名",

    a.bytes / 1024 / 1024 "表空间大小(M)",

    (a.bytes - b.bytes) / 1024 / 1024 "已使用空间(M)",

    b.bytes / 1024 / 1024 "空闲空间(M)",

    round(((a.bytes - b.bytes) / a.bytes) * 100, 2) "使用比"

 

  FROM 

    (SELECT tablespace_name, sum(bytes) bytes FROM dba_data_files GROUP BY tablespace_name) a,

 

    (SELECT tablespace_name, sum(bytes) bytes, max(bytes) largest FROM dba_free_space GROUP BY tablespace_name) b

 

  WHERE 

    a.tablespace_name = b.tablespace_name

 

  ORDER BY 

    ((a.bytes - b.bytes) / a.bytes) DESC

 

 

第二步:增大所需表空间大小:

  alter database datafile '表空间位置'resize 新的尺寸

对于oracle数据库的表空间,除了用手动增加大小外,还可以增加数据文件等方式扩展表空间大小。

方法一:增加数据文件个数

  alter tablespace 表空间名称 add datafile '新的数据文件地址' size 数据文件大小

方法二:设置表空间自动扩展。

  alter database datafile '数据文件位置' autoextend on next 自动扩展大小 maxsize 最大扩展大小

方法三:查询表空间使用情况:

  select

    a.tablespace_name,a.bytes/1024/1024 "sum MB",

     (a.bytes-b.bytes)/1024/1024 "used MB",b.bytes/1024/1024 "free MB", 

    round (((a.bytes-b.bytes)/a.bytes)*100,2) "used%"

  from

     (select tablespace_name,sum(bytes) bytes from dba_data_files group by tablespace_name) a,

     (select tablespace_name,sum(bytes) bytes,max (bytes) largest from dba_free_space group by tablespace_name)b 

  where

    a.tablespace_name=b.tablespace_name 

  order by ((a.bytes-b.bytes)/a.bytes) desc;

 

posted on 2018-05-29 09:20  白衣·沽酒  阅读(314)  评论(0编辑  收藏  举报

导航