Oracle解决Ora-01653无法扩展表空间

问题说明: 
在生成大批量数据进行性能测试时,先通过存储过程生成当前表数据100w条,然后在通过另一个存储过程,以当前表数据为基础,生成过去两个月的数据—-也就是说,历史表包含60天的数据,每天的数据量为100w条,如果顺利生成则历史表会有6000w条数据。 
当前表数据生成完成后,执行生成历史表数据的存储过程遇到“ORA-01653: unable to extend table”的错误。

问题解决: 
出现这种表空间不足的问题一般有两种情况: 
1、表空间确实不够用了,已经达到了自动扩展的上限; 
2、表空间的自动扩展功能没有开。

先针对可能性1查看表空间使用情况 
SELECT UPPER(F.TABLESPACE_NAME) “表空间名”, 
D.TOT_GROOTTE_MB “表空间大小(M)”, 
D.TOT_GROOTTE_MB – F.TOTAL_BYTES “已使用空间(M)”, 
TO_CHAR(ROUND((D.TOT_GROOTTE_MB – F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),’990.99’) “使用比”, 
F.TOTAL_BYTES “空闲空间(M)”, 
F.MAX_BYTES “最大块(M)” 
FROM (SELECT TABLESPACE_NAME, 
ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES, 
ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES 
FROM SYS.DBA_FREE_SPACE 
GROUP BY TABLESPACE_NAME) F, 
(SELECT DD.TABLESPACE_NAME, 
ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB 
FROM SYS.DBA_DATA_FILES DD 
GROUP BY DD.TABLESPACE_NAME) D 
WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME 
ORDER BY 4 DESC; 
SELECT T.TABLESPACE_NAME,D.FILE_NAME,D.AUTOEXTENSIBLE,D.BYTES,D.MAXBYTES,D.STATUS 
FROM DBA_TABLESPACES T,DBA_DATA_FILES D 
WHERE T.TABLESPACE_NAME =D.TABLESPACE_NAME 
ORDER BY TABLESPACE_NAME,FILE_NAME; 

通过上表我们可以看出,表空间***_TRD的表空间的空间使用率已经达到99.6%,只剩下133.88M可用,而其索引空间 ***_TRD_IDX的空间使用率更是达到了99.97%,只剩下4.94M可用。

再查看表空间是否开启了自动扩展的功能 
SELECT T.TABLESPACE_NAME,D.FILE_NAME,D.AUTOEXTENSIBLE,D.BYTES,D.MAXBYTES,D.STATUS 
FROM DBA_TABLESPACES T,DBA_DATA_FILES D 
WHERE T.TABLESPACE_NAME =D.TABLESPACE_NAME 
ORDER BY TABLESPACE_NAME,FILE_NAME; 
 
从上表可以看出,所有的表空间都开启了自动扩展的功能,而且状态都是available的

综合上述检查结果,可断定遇到的问题是因为可能性1—表空间不足导致。解决办法也就是扩大表空间

扩大表空间的四种方法: 
1、增加数据文件 
ALTER TABLESPACE ***_TRD ADD DATAFILE 
‘D:\ORACLE\PRODUCT\10.2.0\ORADATA\DBFILE\TRD_2.DBF’ SIZE 1024M;

2、增加数据文件并允许自动增长 
ALTER TABLESPACE ***_TRD ADD DATAFILE 
‘D:\ORACLE\PRODUCT\10.2.0\ORADATA\DBFILE\TRD_2.DBF’ SIZE 1024M AUTOEXTEND ON NEXT 8M MAXSIZE 10240M;

3、允许已存在的数据文件自动增长 
ALTER DATABASE DATAFILE ‘D:\ORACLE\PRODUCT\10.2.0\ORADATA\DBFILE\TRD.DBF’ 
AUTOEXTEND ON NEXT 8M MAXSIZE 10240M;

4、手工改变已存在数据文件的大小 
ALTER DATABASE DATAFILE ‘D:\ORACLE\PRODUCT\10.2.0\ORADATA\DBFILE\TRD.DBF’ 
RESIZE 10240M;

实际解决过程中,我们使用的是方法2。

对于具体的项目,需要根据表空间中各个表的实际情况来确定具体那种方法最优,在此不做进一步阐述
 

    原文作者:金箍一梦何来愁
    原文地址: https://blog.csdn.net/yz18931904/article/details/89638206
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞