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;