溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

oracle11g 數(shù)據(jù)庫(kù)導(dǎo)出報(bào)“ EXP-00003: 未找到段 (0,0) 的存儲(chǔ)定義”錯(cuò)誤的解決方案

發(fā)布時(shí)間:2020-08-10 08:29:25 來(lái)源:ITPUB博客 閱讀:324 作者:skyin_1603 欄目:關(guān)系型數(shù)據(jù)庫(kù)

導(dǎo)出oracle11.2.0.2的服務(wù)器的數(shù)據(jù)時(shí),報(bào)“EXP-00003: 未找到段 (0,0) 的存儲(chǔ)定義”錯(cuò)誤。初步分析是由于數(shù)據(jù)表是空表導(dǎo)致該問(wèn)題。

Oracle 11G在用EXPORT導(dǎo)出時(shí),空表不能導(dǎo)出11GR2中有個(gè)新特性,當(dāng)表無(wú)數(shù)據(jù)時(shí),不分配segment,以節(jié)省空間
----解決方法:
一、 insert一行,再rollback就產(chǎn)生segment了:
#該方法是在在空表中插入數(shù)據(jù),再刪除,則產(chǎn)生segment。導(dǎo)出時(shí)則可導(dǎo)出空表。

二、 設(shè)置deferred_segment_creation 參數(shù):
--該參數(shù)值默認(rèn)是TRUE,當(dāng)改為FALSE時(shí),無(wú)論是空表還是非空表,都分配segment。修改SQL語(yǔ)句:
alter system setdeferred_segment_creation=false scope=both;
 
#需注意的是:該值設(shè)置后對(duì)以前導(dǎo)入的空表不產(chǎn)生作用,仍不能導(dǎo)出,只能對(duì)后面新增的表產(chǎn)生作用。如需導(dǎo)出之前的空表,只能用第一種方法。

三、 用以下這句查找空表:
select'alter table '||table_name||' allocate extent;' from user_tables wherenum_rows=0;
#把查詢(xún)結(jié)果導(dǎo)出,執(zhí)行導(dǎo)出的語(yǔ)句,強(qiáng)行修改segment值,然后再導(dǎo)出即可導(dǎo)出空表

--可以通過(guò)以下方式生成數(shù)據(jù)庫(kù)更新的sql語(yǔ)句:
在pl/sql的命令窗口中執(zhí)行
set heading off;
   set echo off;
   set feedback off;
   set termout on;
   spool C:\alterTableSql.sql;
   Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0;
   spool off;
#自動(dòng)將空表更新sql生成到C盤(pán)根目錄的alterTableSql.sql文件中。然后執(zhí)行該sql文件更新數(shù)據(jù)庫(kù)。
 

Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0;
也可以換成:
Select 'alter table '||table_name||' allocate extent;' from user_tables where segment_created= 'NO' ;  

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI