原因
- 表空间(tablespace)达到最大值
- 表空间未开启自动扩展
措施
-- 查看所有表空间使用情况
SELECT a.tablespace_name "表空间名",
a.bytes / 1024 / 1024 "表空间大小(M)",
(a.bytes - b.bytes) / 1024 / 1024 "已使用空间(M)",
b.bytes / 1024 / 1024 "空闲空间(M)",
round(((a.bytes - b.bytes) / a.bytes) * 100, 2) "使用比"
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;
结果:
-- 查看表空间SYSTEM的信息,FILE_NAME列为数据文件路径
select tablespace_name,file_name,autoextensible from dba_data_files
where tablespace_name = 'SYSTEM';
结果:
若
AUTOEXTENSIBLE
为NO
,则需要开启
-- 修改为自动扩展开启
alter database datafile '数据文件路径' autoextend on;
调整大小
-- 调整数据文件大小,实际大小请根据情况修改
alter database datafile '数据文件路径' resize 1024M;
其他
本文仅供参考,还望批评指正!