oracle中如何解决导出含clob字段表报错快照过旧问题

网友投稿 714 2023-12-30 16:21:35

oracle中如何解决导出含clob字段表报错快照过旧问题

小编给大家分享一下oracle中如何解决导出含clob字段表报错快照过旧问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

导出含clob字段的表数据,报快照过旧,无法导出该问题是因为含clob字段表数据过大导致,需要修改数据库闪回参数解决查看undo表空间大小是否足够,undo_retention参数是否设置太小,一般跟undo空间无关,只需修改参数即可目前解决办法有两个,加大retention或者使用pctversion另外,对于使用MSSM表空间的表,只有pctverion可用,lob retention不可用

1、加大retention

查看undo参数

SQL> show parameter undo

--修改undo闪回参数

alter system set undo_retention=7200 scope=both;

通过查询oracle官网,oracle的lob大字段有自己的retention参数,如果只调整undo_retention,而没有同步到lob大字段,该参数还是默认的900s,确认查询结果如下:

select table_name,column_name,pctversion,retention from dba_lobs where table_name=T_PATIENT_DOC_COLB;

select table_name,column_name,pctversion,retention from dba_lobs where table_name=T_PATIENTS_DOC_CA;

select table_name,column_name,pctversion,retention from dba_lobs where table_name=T_CARE_DOC;

修改表含有lob大字段的retention设置

ALTER TABLE T_PATIENT_DOC_COLB MODIFY LOB(CONTENT)(retention);

ALTER TABLE T_PATIENTS_DOC_CA MODIFY LOB(SIGN)(retention);

ALTER TABLE T_PATIENTS_DOC_CA MODIFY LOB(TIMESTAMP)(retention);

ALTER TABLE T_CARE_DOC MODIFY LOB(CARE_DOC)(retention);

2、使用pctversion

从结果中可以看到,当显示指定pctversion的时候,retention参数会失效

SQL> alter table T_PATIENTS_DOC_CA modify lob(SIGN) (pctversion 10);

SQL> select column_name, pctversion, retention from user_lobs where table_name = T_PATIENTS_DOC_CA;

COLUMN_NAME          PCTVERSION  RETENTION

------------------------------   ---------   ----------

SIGN                           10

TIMESTAMP                               7200

看完了这篇文章,相信你对“oracle中如何解决导出含clob字段表报错快照过旧问题”有了一定的了解,如果想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:怎样理解Oracle分区表
下一篇:怎么进行Oracle 执行计划的说明
相关文章