Oracle 恢复坏块方法(ORA-01578)—跳过坏块

2023-12-07 04:48

本文主要是介绍Oracle 恢复坏块方法(ORA-01578)—跳过坏块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、创建测试表

SQL> create table test as select * from all_objects;
Table created.
SQL> select count(*) from test;
COUNT(*)
----------
80441

二、人为制造坏块

具体请参考:

http://blog.csdn.net/shiyu1157758655/article/details/79043034


http://blog.csdn.net/shiyu1157758655/article/details/79043618

三、错误现象

1.sqlplus窗口

SQL> select count(*) from test;
select count(*) from test
*
ERROR at line 1:
ORA-01578: ORACLE data block corrupted (file # 5, block # 147)
ORA-01110: data file 5: '/data/CEBPM/datafile/test01.dbf'

2.alter.log文件中 


Hex dump of (file 5, block 147) in trace file /u01/app/oracle/diag/rdbms/cebpm/cebpm/trace/cebpm_ora_8880.trc
Corrupt block relative dba: 0x01400093 (file 5, block 147)
Bad check value found during user buffer read
Data in bad block:
type: 6 format: 2 rdba: 0x01400093
last change scn: 0x0000.0012c1e9 seq: 0x2 flg: 0x04
spare1: 0x0 spare2: 0x0 spare3: 0x0
consistency value in tail: 0xc1e90602
check value in block header: 0x4f1e
computed block checksum: 0x33c4
Reading datafile '/data/CEBPM/datafile/test01.dbf' for corruption at rdba: 0x01400093 (file 5, block 147)
Reread (file 5, block 147) found same corrupt data (no logical check)
Mon Jan 15 08:44:21 2018
Corrupt Block Found
TSN = 5, TSNAME = TEST
RFN = 5, BLK = 147, RDBA = 20971667
OBJN = 83326, OBJD = 83326, OBJECT = TEST, SUBOBJECT = 
SEGMENT OWNER = TEST, SEGMENT TYPE = Table Segment
Errors in file /u01/app/oracle/diag/rdbms/cebpm/cebpm/trace/cebpm_ora_8880.trc  (incident=52714):
ORA-01578: ORACLE data block corrupted (file # 5, block # 147)
ORA-01110: data file 5: '/data/CEBPM/datafile/test01.dbf'
Incident details in: /u01/app/oracle/diag/rdbms/cebpm/cebpm/incident/incdir_52714/cebpm_ora_8880_i52714.trc
Mon Jan 15 08:44:24 2018
Dumping diagnostic data in directory=[cdmp_20180115084424], requested by (instance=1, osid=8880), summary=[incident=52714].
Mon Jan 15 08:44:24 2018
Sweep [inc][52714]: completed
Sweep [inc2][52714]: completed

四、验证是否坏块

1.dbv 验证

cebpm:/home/oracle@cebpm>dbv file=/data/CEBPM/datafile/test01.dbf 
DBVERIFY: Release 11.2.0.4.0 - Production on Mon Jan 15 08:46:29 2018
Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.
DBVERIFY - Verification starting : FILE = /data/CEBPM/datafile/test01.dbf
Page 147 is marked corrupt
Corrupt block relative dba: 0x01400093 (file 5, block 147)
Bad check value found during dbv: 
Data in bad block:
type: 6 format: 2 rdba: 0x01400093
last change scn: 0x0000.0012c1e9 seq: 0x2 flg: 0x04
spare1: 0x0 spare2: 0x0 spare3: 0x0
consistency value in tail: 0xc1e90602
check value in block header: 0x4f1e
computed block checksum: 0x33c4
DBVERIFY - Verification complete
Total Pages Examined         : 4096
Total Pages Processed (Data) : 1158
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 0
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 161
Total Pages Processed (Seg)  : 0
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 2775
Total Pages Marked Corrupt   : 2
Total Pages Influx           : 0
Total Pages Encrypted        : 0
Highest block SCN            : 1229337 (0.1229337)

2.rman验证

RMAN> backup check logical validate datafile 5;
Starting backup at 2018/01/15 08:49:17
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=53 device type=DISK
channel ORA_DISK_1: starting full datafile backup set
channel ORA_DISK_1: specifying datafile(s) in backup set
input datafile file number=00005 name=/data/CEBPM/datafile/test01.dbf
channel ORA_DISK_1: backup set complete, elapsed time: 00:00:03
List of Datafiles
=================
File Status Marked Corrupt Empty Blocks Blocks Examined High SCN
---- ------ -------------- ------------ --------------- ----------
5    FAILED 0              2775         4096            1229337   
File Name: /data/CEBPM/datafile/test01.dbf
Block Type Blocks Failing Blocks Processed
---------- -------------- ----------------
Data       2              1160            
Index      0              0               
Other      0              161             
validate found one or more corrupt blocks
See trace file /u01/app/oracle/diag/rdbms/cebpm/cebpm/trace/cebpm_ora_9284.trc for details
Finished backup at 2018/01/15 08:49:25
SQL> select file#,block#,blocks from v$database_block_corruption;FILE#     BLOCK#	  BLOCKS
---------- ---------- ----------5	  147	       1

五、跳过坏块读取其他数据

SQL>  exec dbms_repair.skip_corrupt_blocks('TEST','TEST');PL/SQL procedure successfully completed.
SQL> select skip_corrupt from user_tables where table_name='TEST';SKIP_COR
--------
ENABLED
SQL> select count(*) from test;COUNT(*)
----------80353

说明:数据发生丢失5号文件的147块中的数据丢失









这篇关于Oracle 恢复坏块方法(ORA-01578)—跳过坏块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/464532

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat