oracle增加表空间大小

oracle增加表空间大小

第一步:查看表空间的名字及文件所在位置:
select tablespace_name, file_id, file_name, round(bytes/(1024*1024),0) total_space from dba_data_files order by tablespace_name
第二步:增大所需表空间大小:
方法一:

alter database datafile '表空间位置’resize 新的尺寸
例如:

alter database datafile '\oracle\oradata\anita_2008.dbf' resize 4000m  

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

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

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

例如:

alter tablespace ESPS_2008 add datafile '\oracle\oradata\anita_2010.dbf' size 1000m
方法三:设置表空间自动扩展。

alter database datafile ‘数据文件位置’ autoextend on next 自动扩展大小maxsize 最大扩展大小
例如:

alter database datafile '\oracle\oradata\anita_2008.dbf' autoextend on next 100m maxsize 10000m
第三步:查询表空间使用情况:
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; 
select a.tablespace_name tablespaceName,
       nvl(b.free,0) "leftSpace",
       nvl(ceil((1 - b.free / a.total) * 100),100) "usageOfTablespace",
       c.EXTENT_MANAGEMENT "extentManagement"
    from (select tablespace_name, sum(nvl(bytes, 0)) / 1024 / 1024 total
            from dba_data_files
           group by tablespace_name) a,
         (select tablespace_name, sum(nvl(bytes, 0)) / 1024 / 1024 free
            from dba_free_space
           group by tablespace_name) b,
         dba_tablespaces c
     where a.tablespace_name = c.tablespace_name
       and c.tablespace_name = b.tablespace_name(+)
       
         AND a.tablespace_name ='REGENTA_DATA' 
       
         order by (1 - b.free / a.total) * 100 desc

你可能感兴趣的:(oracle,oracle,数据库,database)