oracle表空间管理与维护

系统中必须的表空间:SYSTEM、SYSAUX、TEMP、UNDO
表空间的分类:
永久表空间 存放永久性数据,如表,索引等。
临时表空间 不能存放永久性对象,用于保存数据库排序,分组时产生的临时数据。
UNDO表空间 保存数据修改前的镜象。

一、ORACLE 表空间扩展方法

1.方法1

select tablespace_name,               //查看表空间的名字及文件所在位置
       file_id,
       file_name,
       round(bytes / (1024 * 1024), 0) total_space
  from sys.dba_data_files
 order by tablespace_name

alter database datafile '表空间位置' resize 新的尺寸;                 //增大所需表空间大小    
例如alter tablespace ESPS_2008 add datafile '\oracle\oradata\anita_2010.dbf' size 1000m

2.方法2

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;
posted @ 2019-01-17 23:22  reaperhero  阅读(196)  评论(0编辑  收藏  举报