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

相关文章

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

Debian系和Redhat系防火墙配置方式

《Debian系和Redhat系防火墙配置方式》文章对比了Debian系UFW和Redhat系Firewalld防火墙的安装、启用禁用、端口管理、规则查看及注意事项,强调SSH端口需开放、规则持久化,... 目录Debian系UFW防火墙1. 安装2. 启用与禁用3. 基本命令4. 注意事项5. 示例配置R

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi