oracle 表空间扩容

查看表空间的名字及文件所在位置
select tablespace_name,

       file_id,

       file_name,

       round(bytes / (1024 * 1024), 0) total_space

  from sys.dba_data_files

 order by tablespace_name;
查询表空间使用情况
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;
表空间扩容
方法一:增大所需表空间大小:

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;
调整oracle内存
  1. 查看sga大小
show parameter sga;

在这里插入图片描述

  1. 查看memory大小
show parameter memory;

在这里插入图片描述

  1. 调整sga大小

我想把sga_max_size调整为8G

alter system set sga_max_size=8G scope=spfile;

在这里插入图片描述
改完后要重启实例

shutdown immediate;
startup;

在这里插入图片描述
从上图可以看到,实例启动失败,原因是sga_max_size大小不能比memory_target。那么问题来了,此时我已经关闭Oracle了,spfile文件是二进制文件,不能手动修改。

  1. 生成pfile和spfile文件

实例启动不了,spfile文件是二进制文件,也修改不了。要想调整sga_max_size大小,只能重新生成spfile文件。

  • 由spfile产生pfile
create pfile from spfile;

可以生成一个 INIT+实例名.ORA 格式的pfile文件
在这里插入图片描述
打开该文件

在这里插入图片描述
现在就可以调整 memory_targetsga_max_size 的大小(sga_max_size不能大于memory_target)

  • 由pfile生成spfile

生成新spfile文件之前,记得备份旧的spfile

create spfile from pfile;

可以生成一个 SPFILE+实例名.ORA 格式的spfile文件
在这里插入图片描述
再启动实例发现可以启动成功了!
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值