oracle ora-01578 ORACLE 数据块损坏 (文件号 4, 块号 840339)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle ora-01578 ORACLE 数据块损坏 (文件号 4, 块号 840339)相关的知识,希望对你有一定的参考价值。

ORA-01578是 数据块物理坏块/损坏的一种,不同于逻辑损坏/坏块,一般 会伴随ORA-1110出现,一旦ORACLE读取到存在损坏的块就会报出Caused by: java.sql.SQLException: ORA-01578: ORACLE 数据块损坏 (文件号 4, 块号 840339)
ORA-01110: 数据文件 4: ‘E:\APP\ADMINISTRATOR\ORADATA\ORCL\USERS01.DBF‘

解决方法如下:
1、使用DBV检查数据文件,在cmd目录下直接输入dbv file=‘E:\APP\ADMINISTRATOR\ORADATA\ORCL\USERS01.DBF‘ blocksize=8192;然后等待检测结果
2、检查损坏相关的表
SELECT tablespace_name, segment_type, owner, segment_name FROM dba_extents  WHERE file_id = 4 and 840339 between block_id AND block_id + blocks - 1;
查到相关的表名
3、内部事件,设置在全表扫描时跳过损坏的数据块:ALTER SYSTEM SET EVENTS=‘10231 trace name context forever,level 10‘;
4、导出上边相关的表没有损坏的数据exp test/test file=t.dmp tables=t
5、删除损坏相关的表 drop table t;
再将数据做导入imp test/test file=t.dmp tables=t


以上是关于oracle ora-01578 ORACLE 数据块损坏 (文件号 4, 块号 840339)的主要内容,如果未能解决你的问题,请参考以下文章

12 oracle 数据库坏块--物理坏块-ORA-01578/ORA-01110

出现错误 ORA-01578: ORACLE 数据块损坏 (文件号 1, 块号 61338)

ORACLE 数据文件有坏块,报错:ORA-01578:ORACLE data block corrupted(file# 6,block#143589)~ORA-01110:

ORA-01578: ORACLE 数据块损坏 (文件号 13, 块号 2415081) ORA-01110: 数据文件XXXXXX

ORA-01578: ORACLE data block corrupted ORA-01110: data file 5: ‘+DATA/yjt/datafile/undotbs2.264.994(

ORA-01578: ORACLE data block corrupted ORA-01110: data file 5: ‘+DATA/yjt/datafile/undotbs2.264.994(