Hint IGNORE_ROW_ON_DUPKEY_INDEX 引发的ora-600错误

看到 http://yangtingkun.itpub.net/post/468/492325 里 描述 当使用此hint时 批量插入的行数超过255行就会引发错误:ORA-00600: 内部错误代码, 参数; [qerltcInsertSelectRop_bad_state], [], [], [], [], [], [], [], [], [], [], []
在本地环境试了一下确实如此
Connected to Oracle Database 11g Enterprise Edition Release 11.2.0.1.0

SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_user,PK_USER)*/ INTO cm_user SELECT * FROM cm_user@dev_wos.domain WHERE ROWNUM<77;
 
INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_user,PK_USER)*/ INTO cm_user SELECT * FROM cm_user@dev_wos.domain WHERE ROWNUM<77
 
ORA-00600: internal error code, arguments: [qerltcInsertSelectRop_bad_state], [], [], [], [], [], [], [], [], [], [], []
 
SQL> rollback
  2  /
 
Rollback complete
 
Executed in 0.047 seconds
 
SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_user,PK_USER)*/ INTO cm_user SELECT * FROM cm_user@dev_wos.domain WHERE ROWNUM<76;
 
75 rows inserted
 
Executed in 0.016 seconds
 
SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_user,PK_USER)*/ INTO cm_user SELECT * FROM cm_user@dev_wos.domain WHERE ROWNUM<76;
 
0 rows inserted
 
Executed in 0.031 seconds
插入总行数超过75行报错(初始行数100)

SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_location,PK_LOCATION)*/ INTO cm_location SELECT * FROM cm_location@dev_wos.domain WHERE ROWNUM<100;
 
99 rows inserted
 
Executed in 0.266 seconds
 
SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_location,PK_LOCATION)*/ INTO cm_location SELECT * FROM cm_location@dev_wos.domain WHERE ROWNUM<116;
 
INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_location,PK_LOCATION)*/ INTO cm_location SELECT * FROM cm_location@dev_wos.domain WHERE ROWNUM<116
 
ORA-00600: internal error code, arguments: [qerltcInsertSelectRop_bad_state], [], [], [], [], [], [], [], [], [], [], []
插入总行数超过115行报错(初始行数99)

看来不同的表的批量处理上限还不一样

又在 11.2.0.2.0上试了一下 没有发现这个错误,看来是修复了

SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_location,PK_LOCATION)*/ INTO cm_location SELECT * FROM cm_location WHERE ROWNUM<100;
 
0 rows inserted
 
Executed in 0.11 seconds
 
SQL> rollback
  2  /
 
Rollback complete
 
Executed in 0 seconds
 
SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_location,PK_LOCATION)*/ INTO cm_location SELECT * FROM cm_location WHERE ROWNUM<1000;
 
0 rows inserted
 
Executed in 0.297 seconds
 
SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_location,PK_LOCATION)*/ INTO cm_location SELECT * FROM cm_location WHERE ROWNUM<10000;
 
0 rows inserted
 
Executed in 4.235 seconds
 
SQL> INSERT /*+ IGNORE_ROW_ON_DUPKEY_INDEX (cm_location,PK_LOCATION)*/ INTO cm_location SELECT * FROM cm_location ;
 
0 rows inserted
 
Executed in 43.562 seconds

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24022604/viewspace-711470/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/24022604/viewspace-711470/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值