oracle 表空间 擴容,oracle 表空间扩容方法

测试环境

OS:RedHat 6.7

Oracle:11.2.0.4

[root@iccsdb01 ~]# su - oracle

[oracle@iccsdb01 ~]$ 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

SYS@icsdb >

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

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值