1. 程式人生 > >oracle 表空間不足解決辦法大全

oracle 表空間不足解決辦法大全

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 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;