1. 程式人生 > >oracle 表空間擴容方法

oracle 表空間擴容方法

oracle 表空間擴容方法

測試環境

OS:RedHat 6.7

Oracle:11.2.0.4


[[email protected] ~]# su - oracle

[[email protected] ~]$ sqlplus / as sysdba


SQL*Plus: Release 11.2.0.4.0 Production on 星期四 5月 25 15:09:24 2017


Copyright (c) 1982, 2013, Oracle. All rights reserved.



連接到:

Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options


[email protected] >



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


set linesize 200

col FILE_NAME for a50

col TABLESPACE_NAME for a20

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 database datafile ‘/ora_data/icsdb/system01.dbf‘ resize 500M;


對於oracle數據庫的表空間,除了用手動增加數據文件大小外,還可以增加數據文件數量等方式擴展表空間大小。

方法二:增加數據文件個數

alter tablespace 表空間名稱 add datafile ‘新的數據文件地址‘ size 數據文件大小

例如:

alter tablespace system add datafile ‘/ora_data/icsdb/system02.dbf‘ size 1G;


方法三:設置表空間自動擴展。

alter database datafile ‘數據文件位置‘ autoextend on next 自動擴展大小 maxsize 最大擴展大小

例如:

alter database datafile ‘/ora_data/icsdb/system02.dbf‘ autoextend on next 500m 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;

本文出自 “記錄點滴學習” 博客,請務必保留此出處http://laobaiv1.blog.51cto.com/2893832/1929403

oracle 表空間擴容方法