您好,登錄后才能下訂單哦!
本篇內容主要講解“exp報錯與exp為何導不出某些表結構原因是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“exp報錯與exp為何導不出某些表結構原因是什么”吧!
11G中有個新特性,當表無數據時,不分配segment,以節省空間
解決方法:
設置deferred_segment_creation 參數
修改配置參數
sqlplus /nolog
SQL>connect system/password as sysdba;
SQL>show parameter deferred_segment_creation;
你會看到它默認為true,修改。
SQL>alter system set deferred_segment_creation=false;
重啟oracle服務。
show parameter deferred_segment_creation
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
deferred_segment_creation boolean TRUE
SQL> alter system set deferred_segment_creation=false;
系統已更改。
SQL> show parameter deferred_segment_creation
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
deferred_segment_creation boolean FALSE
該參數值默認是TRUE,當改為FALSE時,無論是空表還是非空表,都分配segment。
需注意的是:該值設置后對以前導入的空表不產生作用,仍不能導出,只能對后面新增的表產生作用。如需導出之前的空表,只能用第一種方法。
搞了我好久,最后查到這個方法。
先查詢一下當前用戶下的所有空表
select table_name from user_tables where NUM_ROWS=0;
用以下這句查找空表
select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 or segment_created='NO'
把查詢結果導出,執行導出的語句
'ALTERTABLE'||TABLE_NAME||'ALLOCATEEXTENT;'
與
原因:
LT_EXPORT_PKG在10.2.0.4之前,應該在SYS模式下,但在10.2.0.4及之后,該包已經移到WMSYS模式下.
檢查EXPPKGACT$表內容
select * from sys.exppkgact$ wherepackage='LT_EXPORT_PKG';
解決方法:
create table sys.exppkgact$_backup asselect * from sys.exppkgact$; --備份表
delete fromsys.exppkgact$ where package ='LT_EXPORT_PKG'; --刪除表里值為 LT_EXPORT_PKG 這個的數據
到此,相信大家對“exp報錯與exp為何導不出某些表結構原因是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。