oracle表空间不足,一般有两个原因:一,原表空间太小,没有自增长;二,表空间已自增长,而且表空间也已足够大,对于这两种原因分别有各自的解决办法。
【检查原因】
1、查看表在那个表空间 select tablespace_name,table_name from user_talbes where table_name='test';
2、获取用户的默认表空间 select username, DEFAULT_TABLESPACE from dba_users where username='MXH';
3、查看表空间所有的文件 select * from dba_data_files where tablespace_name='USERS';
4、查询表空间使用情况
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 1
【解决办法-原因一】
只要将表空间设置为足够大,并设置为自增长即可。
1、扩展表空间 alterdatabase datafile 'D:\ORACLE\PRODUCT\ORADATA\TEMP01.DBF' resize 50m;
注:50m,是表空间大小,可以根据实际需要加大,但最大不得超过32G
2、自动增长 alterdatabase datafile 'D:\ORACLE\PRODUCT\ORADATA\TEMP01.DBF' autoextend onnext 50m maxsize 500m;
【解决办法-原因二】
因为表空间中的数据文件已经足够大(达到32G),所以,这时仅仅增加表空间大小是不行的。
这个时候,我们可以增加该表空间的数据文件,这样表空间的大小即变为64G了。
ALTER TABLESPACE aaa
ADD DATAFILE 'D:\ORACLE\PRODUCT\ORADATA\TEMP02.DBF'
SIZE 32767M;