1. 程式人生 > >oracle exp使用遇到語句錯誤無法執行或錯誤ORA-01455

oracle exp使用遇到語句錯誤無法執行或錯誤ORA-01455

簡單記錄一下。關於Oracle  exp匯出操作注意的地方。

1、客戶端安裝,環境變數配置:path  or  NLS_LANG

2、匯出過程中存在問題

    a、匯出語句:exp userid=username/password@ip/dbname indexes=n statistics=none owner=ownername file=dric

           password 存在“@“請注意,防止與ip前的"@"衝突,導致執行失敗。需要把password加上3個引號,如"""password"""

     b、出現ORA-01455: converting column overflows integer datatype

          原因是存在空表,user_segments中對於空表沒有記錄導致無法匯出。

         可以參考: http://blog.itpub.net/20893244/viewspace-2214479/

        解決辦法:

                  select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0   --把現有空表設定一下

                  alter system set deferred_segment_creation=false  --為以後建立的空表設定。

                 show parameter deferred_segment_creation --檢視 deferred_segment_creation 狀態