检查数据块损坏(Block Corruption)

来源:这里教程网 时间:2026-03-03 12:53:46 作者:

Oracle提供了很多工具用来检查数据块是否损坏,下面给大家介绍下 1.1DBVERIFY工具 数据块的物理错误可以通过DBV命令检查出来。 [oracle@pxboracle ~]$ dbv file=/u01/app/oracle/oradata/orcl/test01.dbf blocksize=8192 1.2RMAN的backup命令 RMAN的backup命令在备份时可以检查数据块的物理错误。 RMAN> backup datafile /u01/app/oracle/oradata/orcl/test01.dbf; 1.3RMAN的backup validate 命令 RMAN> backup validate database;        ---验证所有文件,包括数据文件、控制文件、参数文件 RMAN> backup validate datafile 4;        ---验证4号数据文件  1.4DBMS_HM包 DBMS_HM包的RUN_CHECK可以检查数据块物理错误。它可以只检测一个区(extents)。 SYS@devdb>   1 begin   2  dbms_hm.run_check(   3  check_name => 'Data Block Integrity Check',   4  run_name => 'df4test',--检查4号文件中test表   5  input_params => 'BLC_DF_NUM=4;BLC_BL_NUM=128');--'BLC_DF_NUM=4 表示4号文件,BLC_BL_NUM=128--块号   6  end;   7  /

  --- 查看检查报告可以发现 4 号数据文件中 块的损坏。 SYS@devdb>select dbms_hm.get_run_report('df4test') from dual;

---删除检测的所有的报告

SYS@devdb> 1. begin 2.dbms_hm.drop_schema(); 3.end; / 1.5 exp/expdp命令 exp/expdp命令导出数据库时会完全扫描每个数据块,所以也会检查出数据块的物理错误。 [oracle@devdb ~]$ exp scott/oracle owner=scott 1.6 使用DBMS_REPAIR包 DBMS_REPAIR包可以检查表和索引对象的数据块损坏情况。 begin    dbms_repair.admin_tables(table_name => 'REPAIR_1',                             table_type => dbms_repair.REPAIR_TABLE,                             action     => dbms_repair.CREATE_ACTION); end; declare    cor number; begin    dbms_repair.check_object(schema_name       => 'SYS',                             object_name       => 'BIG',                             repair_table_name => 'REPAIR_1',                             corrupt_count     => cor);    dbms_output.put_line(cor); end; select * from REPAIR_1;

相关推荐