[20201111]11.2.0.4版本仍然存在的一個未修復Bug ora-00600 [13013].txt
[20201111]11.2.0.4版本仍然存在的一個未修復Bug ora-00600 [13013].txt
%e7%89%88%e6%9c%ac%e4%bb%8d%e7%84%b6%e5%ad%98%e5%9c%a8%e7%9a%84%e4%b8%80%e4%b8%aa%e6%9c%aa%e4%bf%ae%e5%a4%8dbug-ora-00600-13013/
ORA-00600: internal error code, arguments: [13013], [5001], [3636415], [98890439], [54], [98890439], [17], [], [], [], [], []
針對該錯誤,Oracle mos有文件進行了解釋,這裡不多說:
ORA-600 [13013] [a] [b] [c] [d] [e] [f]
Arg [a] Passcount
Arg [b] Data Object number
Arg [c] Tablespace Relative DBA of block containing the row to be updated
Arg [d] Row Slot number
Arg [e] Relative DBA of block being updated (should be same as [c])
Arg [f] Code
--//98890439 = set dba 23,2421447 = alter system dump datefile 23 block 2421447 = 0x5e4f2c7
--//連結提供例子,可以重複演示這個bug:
CREATE TABLE TAB1 ( ID_NACE NUMBER(5) );
insert into TAB1 values(0);
ALTER TABLE TAB1 ADD (ID_INDUSTRY NUMBER(5) DEFAULT -1 NOT NULL);
ALTER TABLE TAB1 ADD (ID_ind2 varchar2(1) DEFAULT 'U' NOT NULL );
ALTER TABLE TAB1 ADD ( err varchar2(30));
insert into TAB1 values(1, 1, 'C',null);
insert into TAB1 values(2, 2, 'C',null);
CREATE TABLE TAB2 (ID_NACE NUMBER(5),ID_INDUSTRY NUMBER(5));
insert into TAB2 values(1, 3);
commit;
update tab1
set err = 'xxxxx'
where id_ind2 = 'C'
and not exists (select 1 from tab2 where tab2.id_nace = tab1.id_nace and
tab2.ID_INDUSTRY = tab1.ID_INDUSTRY);
update tab1
*
ERROR at line 1:
ORA-00600: internal error code, arguments: [13013], [5001], [94594], [16779067], [1], [16779067], [17], [], [], [], [], []
--//16779067 = set dba 4,1851 = alter system dump datefile 4 block 1851 = 0x100073b
SCOTT@book> select rowid,tab1.* from tab1;
ROWID ID_NACE ID_INDUSTRY I ERR
------------------ ---------- ----------- - ------------------------------
AAAXGCAAEAAAAc7AAA 0 -1 U
AAAXGCAAEAAAAc7AAB 1 1 C
AAAXGCAAEAAAAc7AAC 2 2 C
SCOTT@book> @ rowid AAAXGCAAEAAAAc7AAA
OBJECT FILE BLOCK ROW ROWID_DBA DBA TEXT
---------- ---------- ---------- ---------- -------------------- -------------------- ----------------------------------------
94594 4 1851 0 0x100073B 4,1851 alter system dump datafile 4 block 1851
SCOTT@book> select * from dba_objects where object_name like 'TAB%' and owner=user
2 @ prxx
==============================
OWNER : SCOTT
OBJECT_NAME : TAB1
SUBOBJECT_NAME :
OBJECT_ID : 94594
DATA_OBJECT_ID : 94594
OBJECT_TYPE : TABLE
CREATED : 2020-11-11 10:18:09
LAST_DDL_TIME : 2020-11-11 10:18:19
TIMESTAMP : 2020-11-11:10:18:19
STATUS : VALID
TEMPORARY : N
GENERATED : N
SECONDARY : N
NAMESPACE : 1
EDITION_NAME :
==============================
OWNER : SCOTT
OBJECT_NAME : TAB2
SUBOBJECT_NAME :
OBJECT_ID : 94595
DATA_OBJECT_ID : 94595
OBJECT_TYPE : TABLE
CREATED : 2020-11-11 10:18:28
LAST_DDL_TIME : 2020-11-11 10:18:28
TIMESTAMP : 2020-11-11:10:18:28
STATUS : VALID
TEMPORARY : N
GENERATED : N
SECONDARY : N
NAMESPACE : 1
EDITION_NAME :
PL/SQL procedure successfully completed.
--//這個11g新特性增加欄位預設值導致的問題。
SYS@book> @ hide _add_col_optim_enabled
NAME DESCRIPTION DEFAULT_VALUE SESSION_VALUE SYSTEM_VALUE ISSES ISSYS_MOD
---------------------- ---------------------------------- ------------- ------------- ------------ ----- ---------
_add_col_optim_enabled Allows new add column optimization TRUE TRUE TRUE TRUE IMMEDIATE
SYS@book> @ prxx
==============================
NAME : _add_col_optim_enabled
DESCRIPTION : Allows new add column optimization
DEFAULT_VALUE : TRUE
SESSION_VALUE : TRUE
SYSTEM_VALUE : TRUE
ISSES_MODIFIABLE : TRUE
ISSYS_MODIFIABLE : IMMEDIATE
PL/SQL procedure successfully completed.
SCOTT@book> alter session set "_add_col_optim_enabled"=false;
Session altered.
/* Formatted on 2020/11/11 10:30:33 (QP5 v5.269.14213.34769) */
UPDATE Tab1
SET err = 'xxxxx'
WHERE id_ind2 = 'C'
AND NOT EXISTS
(SELECT 1
FROM tab2
WHERE tab2.id_nace = tab1.id_nace
AND tab2.ID_INDUSTRY = tab1.ID_INDUSTRY);
--//我的測試修改引數也無效。噢不對,這個引數在alter table時才有效。
--//比較笨的方法就是重新建立表才執行就可以透過。
SCOTT@book> create table tab1x as select * from tab1;
Table created.
SCOTT@book> rename tab1 to tab1y;
Table renamed.
SCOTT@book> rename tab1x to tab1;
Table renamed.
UPDATE Tab1
SET err = 'xxxxx'
WHERE id_ind2 = 'C'
AND NOT EXISTS
(SELECT 1
FROM tab2
WHERE tab2.id_nace = tab1.id_nace
AND tab2.ID_INDUSTRY = tab1.ID_INDUSTRY);
2 rows updated.
--//OK現在修改成功!!
SCOTT@book> select * from tab1;
ID_NACE ID_INDUSTRY I ERR
---------- ----------- - ------------------------------
0 -1 U
1 1 C xxxxx
2 2 C xxxxx
--//查詢那些物件有這樣情況,查詢字典sys.ecol$。
SCOTT@book> column BINARYDEFVAL format a40
SCOTT@book> select * from sys.ecol$;
TABOBJ# COLNUM BINARYDEFVAL
---------- ---------- ----------------------------------------
94594 2 3E6466
94594 3 55
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2733436/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Swoole v4.6.1 版本釋出,Bug 修復版本
- ORA-00600: internal error code, arguments: [13013], [5001], [267], [8389014]Error
- [20201111]CURSOR_SPACE_FOR_TIME.txt
- KDE Plasma 5的第二個bug修復版本釋出,帶來了很多的改變ASM
- Gitea 1.11.1 釋出了,修復了 14 個 bugGit
- [20201111]PL SQL function 和一致性.txtSQLFunction
- 時隔兩年,PuTTY 釋出了一個新的安全修復版本
- 微軟修復Bug的補丁產生了新的Bug微軟
- 開放世界遊戲仍然存在的10個問題遊戲
- go-carbon 1.3.5 版本釋出,修復已知bug和優化效能Go優化
- Oracle索引修復 ,ORA-00600: internal error code, arguments: [6200],Oracle索引Error
- [BUG反饋]將1.0版本和1.1版本的BUG整理一下,看看有沒有還存在的。
- flexible.js 相容bug修復FlexJS
- go-carbon 1.3.7 版本釋出,修復時區bug和統一程式碼風格Go
- 微軟釋出Win10 19044.2075版本:帶來多個新功能,修復巨量 Bug微軟Win10
- go-carbon 1.3.5 版本釋出,修復已知bug和最佳化效能Go
- CSS之樣式無效BUG的修復CSS
- 被冰封的 Bug:Fishhook Crash 修復紀實Hook
- iOS 12全版本越獄工具釋出,越獄的生存空間仍然存在iOS
- [譯] 我是如何修復 Python 3.7 中一個非常古老的 GIL 競態條件 bug 的Python
- 蘋果釋出iOS12.1.2全球正式版本:修復Bug為主蘋果iOS
- go-carbon 1.4.5版本釋出,修復已知bug和優化功能Go優化
- 修復一個kubernetes叢集
- 在招標檔案找到了一個BUG,只怪我當時太難修復
- Chrome釋出最新版本,修復一個在野0dayChrome
- workman分散式部署遇到的bug以及修復方式分散式
- IOS下box-shadow的詭異bug的修復iOS
- Nacos 2.3.2 正式釋出,修復重大 bug!
- 故障分析 | 讓top命令直接顯示Java執行緒名?-- 解析OpenJDK的一個bug修復Java執行緒JDK
- go-carbon 1.5.1 版本釋出, 修復已知 bug 和新增土耳其翻譯檔案Go
- go-carbon 1.4.5版本釋出,修復已知bug和最佳化功能Go
- bug的一生:軟體測試員,你是如何利用專業技術修復bug的?
- [20201218]資料檔案OS頭的修復.txt
- 微軟修復了Windows 10 1809中的一個網路服務bug 升級遮蔽已解除微軟Windows
- go-carbon 1.4.6版本釋出,修復已知bug和新增翻譯檔案Go
- go-carbon 1.4.2 版本釋出,新增年代和季節系列方法以及修復bugGo
- go-carbon 1.5.0 版本釋出,修復已知 bug 和新增德語翻譯檔案Go
- go-carbon 1.3.4 版本釋出,新增 Century()方法獲取世紀和修復已知 bugGo