ORA-01691:Lob 段无法通过8192(在表空间XXX中)扩展的解决方案

背景描述:某用户的web服务端突然出现数据无法写入问题,一查日志看到问题如下:

ORA-01691:Lob 段USERS.SYS_LOB0000087483C00004$$无法通过8192(在表空间USERS中)扩展。导致数据无法写入。

紧急处理:查询该错误相关信息,给出的答案时表空间不足,增加数据文件。使用该方法成功解决。经查询,已设置自动扩展。


后来,忽然想到会不会是文件大小限制,于是用关键词:orlace单文件限制查询相关技术文档,结果查到以下内容:

当表空间MAXSIZE UNLIMITED时:

  linux系统中,在block size为8K的情况下,(smallfile)数据文件的最大size为32GB。

当表空间大小有设置数值时(MAXSIZE 4096m):

  数据大小临界预先设置的值。

3.解决方法:

  a.当数据文件大小有设置数值时(MAXSIZE 4096m):增加数据文件大小,最大不超过32G。

alter database datafile '文件路径' autoextend on next 100m maxsize 10240M;

  b.当表空间MAXSIZE UNLIMITED时:只能新添加数据文件。

alter tablespace xxx add datafile '数据文件路径‘ size 1000m autoextend on next 100m maxsize UNLIMITED;

 

在oralce默认数据块大小8k情况下,单文件最大为32G;使用大文件在8k情况下数据文件可达32T。

默认块大小不能更改,如需更改需要重建数据库;

由此得出该问题解决办法:1、增加数据文件。2、使用大文件。3、修改数据块大小。

下面是详细解决方案:

环境: linux系统 工具:PL/SQL DEVELOPER

 

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

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;

 

 



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值