zoukankan      html  css  js  c++  java
  • ora600[qesmmCValStat4]一例

    在之前的文章中提到过一个有趣的绘制五角星的SQL,具体SQL语句如下: with a as (select distinct round(sum(x) over(order by n)) x, round(sum(y) over(order by n)) y from (select n, cos(trunc(n / 20) * (1 - 1 / 5) * 3.1415926) * 2 x, sin(trunc(n / 20) * (1 - 1 / 5) * 3.1415926) y from (select rownum - 1 n from all_objects where rownum <= 20 * 5))) select replace (sys_connect_by_path(point, '/'), '/', null) star from (select b.y, b.x, decode(a.x, null, ' ', '*') point from a, (select * from (select rownum - 1 + (select min(x) from a) x from all_objects where rownum <= (select max(x) - min(x) + 1 from a)), (select rownum - 1 + (select min(y) from a) y from all_objects where rownum <= (select max(y) - min(y) + 1 from a))) b where a.x(+) = b.x and a.y(+) = b.y) where x = (select max(x) from a) start with x = (select min(x) from a) connect by y = prior y and x = prior x + 1; 在10.2.0.1版本输入以上SQL可能会出现ORA-00600: internal error code, arguments: [qesmmCValStat4], [3], [1], [], [],[], [], []错误,g10r21_ora_15473.trc。 其调用栈为:qercoFetch->qerhjFetch->qerhjInitializeManagementComponents-> qesmmCStartWorkArea->qesmmCValidateStatus->kgeasnmierr(报错) metalink文档ID 360811.1对该 Bug 4926357进行了描述,该bug可能在9.2.07~10.2.0.1版本中出现,一般由带start with ... ... connect by prior ..子句的查询语句引起;典型的调用栈为:qesmmCValidateStatus<- qesmmCStartWorkArea <-qerhjInitializeManagementComponents <-qerhjFetch ... 未公布的Bug 4401437是Bug 4926357的一个复制品avatar,该Bug已在10.1.0.5, 10.2.0.2, 11.1等版本中修复了。 Oracle support建议的四种解决方式: 1. 打上该Bug的one-off补丁; 2.升级到该Bug已修复的大版本中,例如从10.2.0.1升级到10.2.0.2; 3.设置参数hash_join_enabled(9i中),_hash_join_enabled(10g中),实例级别的或者会话级别的均可,如:
    SQL> select * from v$version;
    
    BANNER
    ----------------------------------------------------------------
    Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - 64bi
    PL/SQL Release 10.2.0.1.0 - Production
    CORE    10.2.0.1.0      Production
    TNS for Linux: Version 10.2.0.1.0 - Production
    NLSRTL Version 10.2.0.1.0 - Production
    
    SQL> alter session set "_hash_join_enabled"=false;
    
    Session altered.
    
    SQL> set pagesize 1400;
    SQL> with a as
    2   (select distinct round(sum(x) over(order by n)) x,
    3                    round(sum(y) over(order by n)) y
    4      from (select n,
    5                   cos(trunc(n / 20) * (1 - 1 / 5) * 3.1415926) * 2 x,
    6                   sin(trunc(n / 20) * (1 - 1 / 5) * 3.1415926) y
    7              from (select rownum - 1 n from all_objects where rownum <= 20 * 5)))
    8  select replace (sys_connect_by_path(point, '/'), '/', null) star
    9    from (select b.y, b.x, decode(a.x, null, ' ', '*') point
    10            from a,
    11                 (select *
    12                    from (select rownum - 1 + (select min(x) from a) x
    13                            from all_objects
    14                           where rownum <= (select max(x) - min(x) + 1 from a)),
    15                         (select rownum - 1 + (select min(y) from a) y
    16                            from all_objects
    17                           where rownum <= (select max(y) - min(y) + 1 from a))) b
    18           where a.x(+) = b.x
    19             and a.y(+) = b.y)
    20   where x = (select max(x) from a)
    21   start with x = (select min(x) from a)
    22  connect by y = prior y and x = prior x + 1;
    
    STAR
    --------------------------------------------------------------------------------
    .................
    20 rows selected.
    4.设置'no_filtering' 提示,如: with a as (select distinct round(sum(x) over(order by n)) x, round(sum(y) over(order by n)) y from (select n, cos(trunc(n / 20) * (1 - 1 / 5) * 3.1415926) * 2 x, sin(trunc(n / 20) * (1 - 1 / 5) * 3.1415926) y from (select rownum - 1 n from all_objects where rownum <= 20 * 5))) select  /*+ no_filtering */ replace (sys_connect_by_path(point, '/'), '/', null) star from (select b.y, b.x, decode(a.x, null, ' ', '*') point from a, (select * from (select rownum - 1 + (select min(x) from a) x from all_objects where rownum <= (select max(x) - min(x) + 1 from a)), (select rownum - 1 + (select min(y) from a) y from all_objects where rownum <= (select max(y) - min(y) + 1 from a))) b where a.x(+) = b.x and a.y(+) = b.y) where x = (select max(x) from a) start with x = (select min(x) from a) connect by y = prior y and x = prior x + 1;

    但是该hint在9.2.0.7版本中可能因为Bug 4752555 'Wrong results from CONNECT BY query'而导致返回错误行数;并且这是一个undocumented hint,所以强烈不推荐使用!

  • 相关阅读:
    JSON与JSONP的区别
    BFC(块级格式上下文)
    面试题--新
    javascript 类数组对象
    WebP 图片实践之路
    HTTP,HTTP2.0,SPDY,HTTPS你应该知道的一些事
    前端面试题目
    JS 中的事件设计
    博客声明
    1.2 线性表的链式表示
  • 原文地址:https://www.cnblogs.com/macleanoracle/p/2967437.html
Copyright © 2011-2022 走看看