oracle 表空间不足解决办法

oracle 表空间不足解决办法

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

最近服务器数据库报ora-01653错误,无法创建新表,有些表插入数据有问题,有些表先删后插的可以

之前已经做了表空间的自动增长,怀疑是表空间文件超过32G(window服务器环境下,oracle数据文件最大32G),经查询果真如此,于是增加一个新的表空间文件,直接设置为32G大小,其实也可以设置较小的值,然后再设为自动增长即可

以下是网上搜的解决方案和检查办法

--1、查看表空间USERS使用情况
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 
and T.TABLESPACE_NAME='USERS'
ORDER BY TABLESPACE_NAME,FILE_NAME;

--2、修改表空间为自动增长
ALTER DATABASE 
    DATAFILE 'D:\oradata\orcl\USERS01.DBF' AUTOEXTEND 
    ON NEXT 500M MAXSIZE UNLIMITED

--3、自动增长还是不行,可能是数据库文件满了【注意:DBF文件在windows平台32g就不能用了】,就增加几个数据库文件 
ALTER TABLESPACE USERS ADD DATAFILE 'D:\oradata\orcl\USERS02.DBF' SIZE 1G AUTOEXTEND ON NEXT 1G MAXSIZE 30g;

 

 

 

【检查原因】

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 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,  sum(nvl(a.bytes,0)/(b.bytes)*100),  (100 - (sum(nvl(a.bytes,0))/(b.bytes)*100))  FROM dba_free_space a,dba_data_files b  WHERE a.file_id = b.file_id  GROUP BY b.tablespace_name,b.file_name,b.file_id,b.bytes  ORDER 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;

posted @ 2018-06-16 20:29  八方鱼  阅读(7014)  评论(0)    收藏  举报