当 Kingbase 数据库出现坏块时,Kingbase 数据库在查询到记录时,记录坏块的信息: [KingbaseESSserver]invalid page header in block 1301 of relation “FAMILY_CONTENT”
其中,<1301>代表据坏块的块号,出现这种情况时,应该首先检查是否是硬件及操作系统上 的故障导致 Kingbase 数据库出现坏块。在排除了数据库以外的原因后,再对发生坏块的数据 库对象进行处理。
修复方法 1
如果发生坏块的对象是一个索引,那么可以直接把索引 DROP 掉后,再根据表里的记录进行重建;
如果发生坏块的表的记录可以根据其它表的记录生成的话,那么可以直接把这个表 DROP 掉后重建;
如果有数据库的备份,则恢复数据库的方法来进行修复;
如果表里的记录没有其它办法恢复,那么坏块上的记录就丢失了,只能把表中其它数据块上的记录取出来,然 后对这个表进行重建。
修复方法 2
若含坏块表中含多重约束,如外键等,表结构重建相对复杂,可通过方法一进行解决,或通过下面方法解决:
在 kingbase.conf 文件中设置参数 zero_damaged_pages=true,并重新启动数据库。
通过此方式可忽略表中坏块。 create table xx_bak as select * from xx where 1=2; insert into xx select * from scott.emp offset 16 limit 3;