ORA-01688:擴展ORACLE表空間操作

 

感謝分享:http://blog.itpub.net/31369373/viewspace-2150761/

https://blog.csdn.net/qq_41797451/article/details/80431390

https://blog.csdn.net/guo_cw/article/details/80530726

1、問題現象: 頁面導入數據報錯:ora-01688

2、問題原因:

(1) ORA-01688: 無法通過1024 表空間擴展 ,這個錯誤表明表空間已使用完,且無法分配新的空間。這是因爲表空間擴展方式爲手動模式,而非自動模式;

3、解決法:

(1)、確定是哪個表空間用滿了(查看錶空間利用率):

SELECT c.ts#, c.name,  d.contents, d.extent_management, e.file_bytes, c.used,

       SUBSTR (c.used / e.file_bytes * 100, 1, 5)

  FROM (SELECT name, ts#, SUM(used) used

          FROM (SELECT a.allocated_space * (SELECT value  -- 查詢db_block_size當前值

                                              FROM v$parameter

                                             WHERE name = 'db_block_size') / 1024/ 1024 used,

                        b.ts#, b.name

                  FROM v$filespace_usage a, v$tablespace b

         WHERE a.tablespace_id = b.ts#)

         GROUP BY name, ts#) c,

        dba_tablespaces d,

       (SELECT ts#, SUM(bytes) / 1024/ 1024 file_bytes

          FROM v$datafile

         GROUP BY ts#) e      

 WHERE c.name = d.tablespace_name

   AND e.ts# = c.ts#

 ORDER BY ts#

 

結果:

 

 

(2)現在要擴展表空間:TS_APP_DATA_03,先確定表空間文件:

SELECT FILE#, NAME  FROM V$DATAFILE

結果:

 

(3)更新數據表空間文件大小:

       ALTER DATABASE DATAFILE 9 RESIZE 4G;

說明:此處的 ‘9’是上面查出的FILE# = 9的空間;4G是重新分配的空間大小;

 

(4)更新結果:

 

 

1、查看所有的表空間:SELECT * FROM DBA_TABLESPACES;

2、查看某個用戶的默認表空間:SELECT DEFAULT_TABLESPACE,USERNAME FROM DBA_USERS WHERE USERNAME='username';

3、查看錶空間剩餘容量:SELECT TABLESPACE_NAME,SUM(BYTES) FROM DBA_FREE_SPACE GROUP BY TABLESPACE_NAME;

4、查看錶空間數據文件的信息:SELECT * FROM DBA_DATA_FILES;

5、創建表空間:CREATE TABLESPACE ODI  DATAFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\ODI.DBF ' SIZE 50M AUTOEXTEND ON NEXT 10M PERMANENT EXTENT MANAGEMENT LOCAL;

完整的建表空間語句:CREATE TABLESPACE tablespace_name DATAFILE 'filename' SIZE size [AUTOEXTEND [ON NEXT size | OFF]] [MAXSIZE size][PERMANENT  | TEMPORARY][EXTENT MANAGEMENT DICTIONARY | LOCAL];

6、重命名錶空間:ALTER TABLESPACE oldname RENAME TO newname;

7、設置表空間的讀寫狀態:ALTER TABLESPACE tablespace_name READ ONLY | WRITE;

8、設置表空間的可用狀態:ALTER TABLESPACE tablespace_name ONLINE | OFFLINE [NORAML | TEMPORARY | IMMEDIATE];如果是聯機狀態,那麼表空間就可以被用戶操作,反之設置成脫機狀態,表空間就不是不可用的,脫機狀態還包括3種方式。

9、建立大文件表空間:CREATE BIGFILE TABLESPACE tablespace_name DATAFILE 'filename' SIZE size;

10、刪除表空間:DROP TABLESPACE tablespace_name [INCLUDING CONTENTS][CASCADE CONSTRAINTS];INCLUDING CONTENTS表示把表空間裏的數據文件也刪除,CASCADE CONSTRAINTS會把表空間中的完整性也刪除。

11、臨時表空間一般是指在數據庫中存儲數據,當內存不夠時寫入的空間,這個空間並不像一般的表空間,當執行完對數據庫的操作後,該空間的內容自動清空。

12、創建臨時表空間:CREATE TEMPORARY TABLESPACE tablespace_name TEMPFILE 'filename' SIZE size;

13、設置臨時表空間爲默認表空間:ALTER DATABASE DEFAULT TEMPORARY TABLESPACE tablespace_name;

14、查詢臨時表空間:SELECT * FROM DBA_TMP_FILES;

15、創建臨時表空間組:CREATE TEMPORARY TABLESPACE tablespace_name TMPFILE 'filename' SIZE size TABLESPACE GROUP group_name;

16、移動臨時表空間到表空間組:ALTER TABLESPACE tablespace_name TABLESPACE GROUP group_name;

17、查詢臨時表空間組:SELECT * FROM DBA_TABLESPACE_GROUPS;

18、刪除臨時表空間:DROP TABLESPACE tablespace_name INCLUDING CONTENTS AND DATAFILES;

19、刪除表空間中的數據文件:ALTER TABLESPACE tablespace_name DROP DATAFILE 'filename';

20、向表空間裏增加數據文件:ALTER TABLESPACE tablespace_name ADD DATAFILE 'filename' SIZE size;

21、向表空間裏新增數據文件,並且允許數據文件自動增長:ALTER TABLESPACE tablespace_name ADD DATAFILE 'filename' SIZE 50M AUTOEXTEND ON NEXT 5M MAXSIZE 100M;

22、允許已存在的數據文件自動增長:ALTER DATABASE DATAFILE 'filename' AUTOEXTEND ON NEXT 5M MAXSIZE 100M;

23、手工改變已存在數據文件的大小:ALTER DATABASE DATAFILE 'filename' RESIZE 100M;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章