视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
ORA-600[13013]处理过程
2020-11-09 12:46:29 责编:小采
文档


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

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

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


Thu Mar 08 23:29:37 2012

Errors infile/opt/Oracle/diag/rdbms/chf/chf/trace/chf_smon_24137.trc (incident=38681):

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 whereOBJ# isnotnullorINTCOL# isnotnull;

norowsselected

--无记录返回

Execution Plan

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

Plan hash value: 399371572

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

| Id | Operation | Name| Rows| Bytes | Cost (%CPU)| Time

|

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

| 0 | SELECTSTATEMENT | | 4262 | 76716 | 27 (71)| 00:00:01 |

| 1 | MINUS | | | | | |

| 2 | SORT UNIQUE| | 4262 | 38358 | 9 (12)| 00:00:01 |

| 3 | TABLEACCESS FULL| COL_USAGE$ | 4262 | 38358 | 8 (0)| 00:00:01 |

| 4 | SORT UNIQUENOSORT| | 4262 | 38358 | 18 (6)| 00:00:01 |

|* 5 | INDEXFULLSCAN | I_COL_USAGE$ | 4262 | 38358 | 17 (0)| 00:00:01 |

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

--验证表两个sql是否正确(一个全表扫描,另个index 快速扫描)

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

2 FROMsys.COL_USAGE$ t whereOBJ# isnotnullorINTCOL# isnotnull

3 MINUS

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

5 FROMsys.COL_USAGE$ t1;

OBJ# INTCOL#

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

4294951004 2

4294951004 3

4294951004 4

4294951004 26

4294951004 27

4294951037 4

4294951037 5

4294951037 6

4294951037 9

4294951037 10

4294951840 11

OBJ# INTCOL#

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

4294951840 12

4294951906 4

4294952709 3

4294952867 4

4294952867 9

16 rowsselected.

--证明index中的记录比表中多了16条

解决问题并验证


SQL> alterindexsys.I_COL_USAGE$ rebuild online;

Indexaltered.

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

FROMsys.COL_USAGE$ t1

2 3 MINUS

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

5 FROMsys.COL_USAGE$ t whereOBJ# isnotnullorINTCOL# isnotnull

6 ;

norowsselected

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

2 FROMsys.COL_USAGE$ t whereOBJ# isnotnullorINTCOL# isnotnull

3 MINUS

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

5 FROMsys.COL_USAGE$ t1;

norowsselected

这次出现此问题的原因是因为在更新语句中使用索引找到一条记录,然后到表中去查询时该记录不存在,,出现此错误,一般解决方法是重建索引

Oracle 单实例 从32位 迁移到 位 方法

在CentOS 6.4下安装Oracle 11gR2(x)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2

本文永久更新链接地址:

下载本文
显示全文
专题