oracle 表空间不足解决办法大全

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

【检查原因】

--1、查看表在那个表空间  
select a.owner,tablespace_name, table_name
  from ALL_ALL_TABLES a
 where table_name = 'ZX_NSR_ZGRD_XSB'
 and a.owner = 'DB_SBF';
--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、扩展表空间,注:50m,是表空间大小,可以根据实际需要加大,但最大不得超过32G 
alter database datafile 'D:\ORACLE\PRODUCT\ORADATA\TEST\USERS01.DBF' resize 50m;

--2、自动增长  
alter database 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;

猜你喜欢

转载自tommy-lu.iteye.com/blog/2221910
今日推荐