ORACLE常见错误代码的分析与解决(二)

** ORACLE 常见错误代码的分析与解决(二) **

文章源自于 世纪易网

ORA-01578:Oracle data block corrupted(file # num,block # num)

产生原因:当 ORACLE 访问一个数据块时,由于 1 、硬件的 I/O 错误; 2 、操作系统的 I/O 错误或缓冲问题; 3 、内存或 paging 问

题; 4 、 ORACLE 试图访问一个未被格式化的系统块失败; 5 、数据文件部分溢出等上述几种情况的一种引起了逻辑坏块或者

物理坏块,这时就会报 ORA-01578 的错误。

解决方式:由于 ORACLE 只有在访问到有问题的数据文件时才会报错,所以报错的时间有可能会比实际出错的时间要晚,如

果 ORA-01578 出错信息提示数据坏块指向的是用户自己的数据文件,则用以下方法来解决:

如果通过下面的 SQL 语句查出的坏块出现有索引上,则只需重建索引即可

SQL>Select owner,segment_name,segment_type from dba_extents where file_id=

 1<f> and <b> between block_id and 
 2
 3block_id+blocks-1;(<f>   <b> 分别是  ORA-01578  报出的坏块出现的文件号和块号  ) 
 4
 5如果坏块出现在表上,先用以下语句分析是否为永久性坏块(建议多执行一两次,有助于鉴别数据坏块是永久性的(硬盘 
 6
 7上的物理坏块)还是随机性的(内存或硬件错误引起)): 
 8
 9SQL&gt;Analyze table <table_name> validate structure cascade; 
10
11执行该命令后,可能会出现以下的结果: 
12
13ORA-01578  :与原先错误信息有相同的参数,为永久性的物理或逻辑坏块;与原先错误信息有不同的参数,可能与内存, 
14
15page space    I/O  设备有关。 
16
17如果用户有此表的最新备份,那么最好是用此备份来恢复此表,或者使用  event 10231  来取出坏块以外的数据: 
18
19&lt;1&gt;.  先关闭数据库 
20
21&lt;2&gt;.  编辑  init<sid>.ora  文件,加入: 
22
23event=”10231 trace name context forever,level 10” 
24
25&lt;3&gt;.startup restrict 
26
27&lt;4&gt;.  创建一个临时表:  SQL&gt;create table errortemp as select * from error;(error  是坏表的表名  ) 
28
29&lt;5&gt;.    event    init<sid>.ora  文件中删掉并重起数据库 
30
31&lt;6&gt;.rename  坏表,把临时表  rename  成坏表的表名 
32
33&lt;7&gt;.  创建表上的  INDEX   
34
35如果  ORA-01578  出错信息提示数据坏块指向的是数据字典或者是回滚段的话,你应该立即与  ORACLE  公司联系,共同商量一个 
36
37好的解决办法。 
38
39这里所讲的解决方法只是比较常见的一种,一些更为具体的解决办法可以查看一下  ORACLE  的故障解决手册,那里面有浞及 
40
41使用  ROWID  方法来取出坏块以外的数据的方法,这里就不介绍了。 
42
43相应的英文如下: 
44
45Cause:The given data block was corrupted,probably due to program errors 
46
47Action:Try to restore the segment containing the given data block,This may involve dropping the segment 
48
49and recreating it,If there is a trace file,report the messages recorded in it to customer support. 
50
51ORA-01628:max # of extents num reached for rollback segment num 
52
53产生原因:这种错误通常为一个回滚段和一个表空间已经达到  MAXEXTENTS  参数设置的极限。要注意的是这个  MAXEXTENTS   
54
55是该回滚段或表空间的硬件极限,硬件极限取决于数据库创建时在  init.ora  文件中指定的  DB_BLOCK_SIZE  参数的值。 
56
57解决方法:使用  SQL  命令  ALTER TABLESPACE    STORAGE    MAXEXTENTS XXXX  )来增加  MAXEXTENTS  ,其中“  XXXX  ”值必须大于 
58
59错误信息中所指的数值,但不能大于  LARGEST MAXEXTENT  的值,如果已经达到了  LARGEST MAXEXTENT VALUE  ,解决的办法就 
60
61是重新创建较大的范围尺寸,使用带有选项  COMPRESS=Y    Export  工具导出表,如果表空间有可用空间,先给表做一个备 
62
63份,用  alter tablespace tablespace_name  更改其名字,然后再装载表回数据库。 
64
65查看其错误出现的地方,如果出现在回滚段或索引上,那么必须将其删除并重建,如果出现在临时表空间,修改临时表空 
66
67间的存储字段,便可解决这个问题。 
68
69一个报错例子如下: 
70
71ORA-1628:max # extents 50 reached for rollback segment RBS_1 
72
73相应的英文如下: 
74
75Cause: An attempt was made to extend a rollback segment that already has reached its maximum size or space 
76
77could not be allocated in the data dictionary to contain the definition of the object. 
78
79Action:If possible,increase the value of either the MAXEXTENTS or PCTINCREASE initialization parameters or 
80
81find the data dictionary table lacking space and alter the storage parameters,as described in the Oracle8 
82
83Server Administrators Guide.</sid></sid></table_name></b></f></b></f>
Published At
Categories with 数据库类
Tagged with
comments powered by Disqus