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

相关文章

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能