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、总结
问题的出现一般都是有几种办法,至于如何选择还是要根据自己的情况。
复制
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。