oracle数据泵跳过损坏的lob方法

来源:这里教程网 时间:2026-03-03 21:05:35 作者:

oracle数据泵跳过损坏的lob方法

1、背景


巡检一台用户的服务器时,发现自动备份存在报错情况:

2、分析思路和处理过程


处理过该问题的都知道,这是一个lob段损坏的问题;
解决办法1:找到损坏的内容,清空,重新执行expdp。
解决办法2:找到损坏的内容,记录下来,然后数据泵跳过对应的行记录。


##这里我选择解决办法2:
SQL> create table result (id number, checked_rowid rowid, status varchar2(10), page number, error varchar2(100));

SQL> 
set serverout on

exec dbms_output.enable(100000);

declare
page number;
len number;
c varchar2(10);
charpp number := 8132/2;
n number;
v_sqlerrm varchar2(100);
begin
n := 0;

for r 
in (select rowid rid, dbms_lob.getlength (xmltype.getclobval(content)) len  -- replace column name
from zldoc.bz_doc_log) loop << replace table name
n := n+1;

if r.len is not null 
then

for page 
in 0..r.len/charpp loop
begin
select dbms_lob.substr (xmltype.getclobval(content), 1, 1+ (page * charpp)) --replace column name
into c
from zldoc.bz_doc_log      -- replace table name

where rowid = r.rid;
v_sqlerrm := SQLERRM;
insert into result values (n, r.rid, 
'good', page, v_sqlerrm);
commit;
exception
when others 
then
dbms_output.put_line (
'Error on rowid ' ||r.rid||
' page '||page);
dbms_output.put_line (sqlerrm);
v_sqlerrm := SQLERRM;
insert into result values (n, r.rid, 
'bad',page,v_sqlerrm);
commit;
end;
end loop;
end 
if;
end loop;
end;
/

expdp system/manager DIRECTORY=my_dir DUMPFILE=expdp.dmp LOGFILE=expdp.log TABLES=<USER>.TESTTAB QUERY=\"WHERE rowid NOT IN \(\
'<orrupt_rowid>\'\)\"

3、总结


问题的出现一般都是有几种办法,至于如何选择还是要根据自己的情况。

相关推荐