ORA-01578的解决方式

2023-10-18 21:21
文章标签 解决 方式 ora 01578

本文主要是介绍ORA-01578的解决方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境 :Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 + windows 2003

 

现象描述:

ORA-01578: ORACLE 数据块损坏 (文件号 12, 块号 217816)
ORA-01110: 数据文件 12: 'D:/ORADATA/TS_HIS3LC04'. 

 

处理过程:

1. 先根据文件号,块号定位到segment,语句如下:

 

SQL> SELECT Tablespace_Name, Segment_Type, Owner, Segment_Name
  2    FROM Dba_Extents
  3   WHERE File_Id = 12 AND
  4         217816 BETWEEN Block_Id AND Block_Id + Blocks - 1
  5  /
 
TABLESPACE_NAME                SEGMENT_TYPE       OWNER                          SEGMENT_NAME
------------------------------ ------------------ ------------------------------ --------------------------------------------------------------------
TS_HIS3LC                      INDEX              HIS3LC                         PK_ZY_RIBAO2

 

2. 根据segment_name定位

SQL> SELECT SEGMENT_NAME,SEGMENT_TYPE,TABLESPACE_NAME FROM User_Segments WHERE segment_name = 'PK_ZY_RIBAO2';
 
SEGMENT_NAME                                                                     SEGMENT_TYPE       TABLESPACE_NAME
-------------------------------------------------------------------------------- ------------------ ------------------------------
PK_ZY_RIBAO2                                                                     INDEX              TS_HIS3LC

发现是索引的问题,只需重建即可解决(网上有针对表数据块损坏的解决方法,这次幸亏运气不错,只是索引的问题,呵呵)

 

3. 由于知道是索引问题,可以定位到具体表的索引

SQL> SELECT index_name,table_type,table_name,table_owner FROM user_Indexes WHERE index_name = 'PK_ZY_RIBAO2'
  2  /
 
INDEX_NAME                     TABLE_TYPE  TABLE_NAME                     TABLE_OWNER
------------------------------ ----------- ------------------------------ ------------------------------
PK_ZY_RIBAO2                   TABLE       ZY_RIBAO2                      HIS3LC

 

 4.  尝试重建索引,结果报错

SQL> alter index PK_ZY_RIBAO2 rebuild nologging;
 
alter index PK_ZY_RIBAO2 rebuild nologging
 
ORA-01578: ORACLE data block corrupted (file # 12, block # 217816)
ORA-01110: data file 12: 'D:/ORADATA/TS_HIS3LC04'

 

5. 查询该索引的信息,确定是主键索引

SQL> SELECT constraint_name,table_name FROM user_constraints WHERE table_name = 'ZY_RIBAO2' AND constraint_type = 'P';
 
CONSTRAINT_NAME                TABLE_NAME
------------------------------ ------------------------------
PK_ZY_RIBAO2                   ZY_RIBAO2

 

6. 主键索引直接rebuild会报错,首先要先disable主键

alter table ZY_RIBAO2
  disable constraint PK_ZY_RIBAO2;

 (此时索引已经删除)

 

7.重新添加主键约束

 alter table ZY_RIBAO2
  add constraint PK_ZY_RIBAO2 primary key (MOBANXMID, RIBAOID, JIAOYILX);

 

问题解决。

 

还有种方式可以用plsql里面操作。

 

网上相关文章:

http://blog.chinaunix.net/u/10516/showart_1958140.html

http://www.rbsbooks.com/lopchap6.htm

http://www.eygle.com/faq/Block_corruption.htm

这篇关于ORA-01578的解决方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如

解决Entity Framework中自增主键的问题

《解决EntityFramework中自增主键的问题》:本文主要介绍解决EntityFramework中自增主键的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录Entity Framework中自增主键问题解决办法1解决办法2解决办法3总结Entity Fram

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的