十八、dbms_repair(用于检测,修复在表和索引上的损坏数据块)
1、概述
作用:用于检测,修复在表和索引上的损坏数据块.
2、包的组成
1)、admin_tables
语法:dbms_repair.admin_tables(table_name
in varchar2,table_type in binary_integer,action in
binary_integer,tablespace in varchar2 default null);
其中table_name用于指定要处理的表名,必须要指定前缀orphan或repair,table_type指定表类型(orphan或repair_table),
action指定要执行的管理操作(建立表create_action,删除所有行purge_action,删除表drop_action),tablespace用于指定表所在的表空间。
例子:
exec dbms_repair.admin_tables('repair_table',dbms_repair.repair_table,dbms_repair.create_action,'system');
exec dbms_repair.admin_tables('orphan_table',dbms_repair.orphan_table,dbms_repair.create_action,'system');
上面例子执行第一条语句后,会建立修复表repair_table,并且该修复表用于存放损坏数据块的信息;执行第二条语句后,会建立孤表orphan_table,该表用于存放指向损坏数据块的索引入口信息。
2)、check_object
作用:用于检查特定对象,并将损坏信息填写到修复表中。
语法:dbms_repair.check_object(schema_name
in varchar2,object_name in varchar2,partition_name in varchar2 default
null,object_type in binary_integer default tables_object,
repair_table_name
in varchar2 default 'repair_table',flags in binary_integer default
null,relative_fno in binary_integer default null,
block_start in binary_integer default null,block_end in binary_integer default null,corrupt_count out binary_integer);
其中schema_name指定要检查对象的方案名,object_name指定要检查的对象名,partition_name用于指定要检查的分区名,object_type指定要检查对象的类型(table_object或index_object),
repair_table_name指定要被填写的修复表,flags为将来使用而保留,relative_fno指定相对文件号,block_start指定要检查的起始块号,block_end指定要检查的结束块号,
corrupt_count用于返回损坏的块个数。
例子:
var corr_count number;
exec dbms_repair.check_object('scott','emp',corrupt_count=>:corr_count);
print corr_count
3)、dump_orphan_keys
作用:用于报告指向损坏数据块行的索引入口,并且会将相应索引入口的信息插入到孤表中。
语法:dbms_repair.dump_orphan_keys(schema_name in varchar2,object_name in varchar2,
partition_name in varchar2 default null,object_type in binary_integer default index_object,
repair_table_name in varchar2 default 'repair_table',orphan_table_name in varchar2 default 'orphan_keys_table',
flags in binary_integer default null,key_count out binary_integer);
其中object_type指定对象类型(index_object),repair_table_name指定修复表名,orphan_table_name指定孤表名,key_count用于返回索引入口个数。
例子:
var key_count number
exec dbms_repair.dump_orphan_keys('scott','pk_emp',orphan_table_name=>'orphan_table',key_count=>:key_count);
print key_count
4)、fix_corrupt_blocks
作用:修复被损坏的数据块,这些被损坏的数据块是在执行了check_object之后生成的。
语法:dbms_repair.fix_corrupt_blocks(schema_name in varchar2,object_name in varchar2,partition_name in varchar2 default null,
object_type in binary_integer default table_object,repair_table_name in varchr2 default 'repair_table',
flags in binary_integer default null,fix_count out binary_integer);
其中object_type指定对象类型(table_object),fix_count返回修复的数据块个数。
例子:
var fix_count number
exec dbms_repair.fix_corrup_block('scott','emp',fix_count=>:fix_count);
print fix_count
5)、rebuild_freelists
作用:用于重建指定对象的空闲列表
语法:dbms_repair.rebuild_freelists(schema_name in varchar2,object_name in varchar2,partition_name in varchar2 default null,
object_type in binary_integer default table_object);
其中object_type指定对象类型(table_object)。
例子:exec dbms_repair.rebuild_freelists('scott','emp');
6)、skip_corrupt_blocks
作用:用于指定在扫描对象(表或索引)时跳过损坏块。
语法:dbms_repair.skip_corrupt_blocks(schema_name
in varchar2,object_name in varchar2,object_type in binary_integer
default table_object,
flag in binary_integer default skip_flag);
其中object_type指定对象类型(table_object),flags指定是否要跳过损坏块(skip_flao跳过,no_skip_flag不跳过)
例子:exec dbms_repair.skip_corrupt_blocks('scott','emp');
7)、segment_fix_status
作用:用于修复位图入口的损坏
语法:dbms_repair.segment_fix_status(segment_owner
in varchar2,segment_name in varchar2,segment_type in binary_integer
default table_object,
file_number in binary_integer default null,block_number in binary_integer default null,
status_value in binary_integer default null,partition_name in varchar2 default null);
其中segment_owner指定段所有者,segment_name指定段名,segment_type指定段类型,file_number指定数据块所在的相对文件号,
block_number指定数据块号,status_value指定块状态值(1:全块,2:0~25%,3:25%~50%,4:50%~75%,5:75%~100%)
partition_name指定分区名。
例子:exe dbms_repair.segment_fix_status('sys','mytab');