oracle检测block损坏,检查数据块损坏(Block Corruption)

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值