ORA-600[13013]处理过程(一)

2015-01-21 12:31:25 · 作者: · 浏览: 6

记录一次ORA-600[13013]处理过程


在一次数据库的异常处理完成后,发现alert日志中出现ORA-600[13013]错误



Thu Mar 08 23:29:37 2012


ORA-00600: internal error code, arguments: [13013], [5001], [518], [4198427], [170], [4198427], [17], [], [], [], [], []


Incident details in: /opt/oracle/diag/rdbms/chf/chf/incident/incdir_38681/chf_smon_24137_i38681.trc


Use ADRCI or Support Workbench to package the incident.


See Note 411.1 at My Oracle Support forerror and packaging details.


Non-fatal internal error happenned whileSMON was doing flushing of monitored table stats.


SMON encountered 1 out of maximum 100 non-fatal internal errors.
?


trace文件中信息
从这里可以看出是对sys.col_usage$表进行update操作导致该错误发生



Dump continued from file: /opt/oracle/diag/rdbms/chf/chf/trace/chf_smon_24137.trc


ORA-00600: internal error code, arguments: [13013], [5001], [518], [4198427], [170], [4198427], [17], [], [], [], [], []


========= Dump forincident 38681 (ORA 600 [13013]) ========


*** 2012-03-08 23:29:37.400


dbkedDefDump(): Starting incident default dumps (flags=0x2, level=3, mask=0x0)


----- Current SQL Statement forthis session (sql_id=3c1kubcdjnppq) -----


update sys.col_usage$ setequality_preds = equality_preds + decode(bitand(:flag,1),0,0,1), equijoin_preds = equijoin_preds + decode(bitand(:flag,2),0,0


,1), nonequijoin_preds = nonequijoin_preds + decode(bitand(:flag,4),0,0,1), range_preds = range_preds + decode(bitand(:flag,8),0,0,1), like_preds


= like_preds + decode(bitand(:flag,16),0,0,1), null_preds = null_preds + decode(bitand(:flag,32),0,0,1), timestamp = :timewhere obj# = :ob


jn and intcol# = :coln
?


MOS中关于ORA-600 [13013]描述



Format: ORA-600 [13013] [a] [b] {c} [d] [e] [f]


Arg [a] Passcount


Arg [b] Data Object number


Arg {c} Tablespace Decimal Relative DBA (RDBA) of block containing the row to be updated


Arg [d] Row Slot number


Arg [e] Decimal RDBA of block being updated (Typically same as {c})


Arg [f] Code
?


验证MOS中描述



SQL> selectdbms_utility.data_block_address_file(4198427) rfile,


2 dbms_utility.data_block_address_block(4198427) blocks


3 fromdual;


RFILE BLOCKS


---------- ----------


1 4123


SQL> SELECTOWNER, SEGMENT_NAME, SEGMENT_TYPE, TABLESPACE_NAME, A.PARTITION_NAME


2 FROMDBA_EXTENTS A


3 WHEREFILE_ID = &FILE_ID


4 AND&BLOCK_ID BETWEENBLOCK_ID ANDBLOCK_ID + BLOCKS - 1;


Enter value forfile_id: 1


old 3: WHEREFILE_ID = &FILE_ID


new 3: WHEREFILE_ID = 1


Enter value forblock_id: 4123


old 4: AND&BLOCK_ID BETWEENBLOCK_ID ANDBLOCK_ID + BLOCKS - 1


new 4: AND4123 BETWEENBLOCK_ID ANDBLOCK_ID + BLOCKS - 1


OWNER SEGMENT_NAME SEGMENT_TY TABLESPACE PARTI


----- ------------ ---------- ---------- -----


SYS COL_USAGE$ TABLESYSTEM


--和trace文件中异常表一致


SQL> selectobject_type,object_name fromdba_objects whereobject_id=518;


OBJECT_TYPE OBJECT_NAME


------------------- ------------------------------


TABLECOL_USAGE$


--也和trace文件中异常表一致
?


分析异常表



SQL> ANALYZE TABLEsys.COL_USAGE$ VALIDATE STRUCTURE CASCADE;


ANALYZE TABLEsys.COL_USAGE$ VALIDATE STRUCTURE CASCADE


*


ERROR atline 1:


ORA-01499: table/indexcrossreference failure - see trace file


SQL> selectindex_name,COLUMN_NAME,COLUMN_POSITION FROMDBA_IND_COLUMNS


2 WHERETABLE_NAME='COL_USAGE$';


INDEX_NAME COLUMN_NAM COLUMN_POSITION


--------------- ---------- ---------------


I_COL_USAGE$ OBJ# 1


I_COL_USAGE$ INTCOL# 2


SQL> setautot trace exp


SQL> SELECT/*+ FULL(t1) */ OBJ#,INTCOL#


2 FROMsys.COL_USAGE$ t1


3 MINUS


4 SELECT/*+ index(t I_COL_USAGE$) */ OBJ#,INTCOL#


5 FROMsys.COL_USAGE$ t whereOB