微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

oracle表空间不足

oracle表空间不足,一般有两个原因:一,原表空间太小,没有自增长;二,表空间已自增长,而且表空间也已足够大,对于这两种原因分别有各自的解决办法。

【检查原因】

1、查看表在那个表空间select tablespace_name,table_name from user_talbes where table_name='test';2、获取用户认表空间selectusername,DEFAULT_TABLESPACEfromdba_users where username='MXH';3、查看表空间所有的文件select * from dba_data_files where tablespace_name='USERS';4、查看表空间使用情况:SELECT tbs 表空间名,sum(totalM) 总共大小M,sum(usedM) 已使用空间M,sum(remainedM) 剩余空间M,sum(usedM)/sum(totalM)*100 已使用百分比,sum(remainedM)/sum(totalM)*100 剩余百分比FROM(SELECT b.file_id ID,b.tablespace_name tbs,b.file_name name,b.bytes/1024/1024 totalM,(b.bytes-sum(nvl(a.bytes,0)))/1024/1024 usedM,sum(nvl(a.bytes,0)/1024/1024) remainedM,0)/(b.bytes)*100),(100 - (sum(nvl(a.bytes,0))/(b.bytes)*100))FROM dba_free_space a,dba_data_files bWHERE a.file_id = b.file_idGROUP BY b.tablespace_name,b.file_name,b.file_id,b.bytesORDER BY b.tablespace_name)GROUP BY tbs

解决办法-原因一】

只要将表空间设置为足够大,并设置为自增长即可。

1、扩展表空间alterdatabase datafile 'D:\ORACLE\PRODUCT\ORADATA\TEST\USERS01.DBF' resize 50m;

注:50m,是表空间大小,可以根据实际需要加大,但最大不得超过32G

2、自动增长alterdatabase datafile 'D:\ORACLE\PRODUCT\ORADATA\TEST\USERS01.DBF' autoextend onnext 50m maxsize 500m;

解决办法-原因二】

因为表空间中的数据文件已经足够大(达到32G),所以,这时仅仅增加表空间大小是不行的。

这个时候,我们可以增加该表空间的数据文件,这样表空间的大小即变为64G了。

ALTER TABLESPACE aaa

ADD DATAFILE 'E:\APP\ORACLE11GR2\ORADATA\ORCL\aaa_DATA02.DBF'

SIZE 32767M;

原文地址:https://www.jb51.cc/oracle/209808.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐