微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Oracle似乎忽略了我给出的所有提示使用sqldeveloper

如何解决Oracle似乎忽略了我给出的所有提示使用sqldeveloper

我只是写下了我的全部问题,由于某种原因,所有内容都被随机删除了,所以这里有一个超级汇总的版本。

我对提示非常陌生,对此却很少受教,我在网上阅读了大量内容并观看了Youtube视频,但是我找不到一个能够提供足够示例和可视化效果的视频,因此我深表歉意。我只是做错了。

这些是我尝试过的提示(我尝试过USE_NLUSE_NL_WITH_INDEXLEADING,但随后发现CBO自动使用了这些提示,很好):

    /*+ USE_MERGE(sale_Saracl CUSTOMER_Saracl) */ 

使用此查询

    SELECT AVG(s.sellprice),s.qty,s.custid  
    FROM CUSTOMER_Saracl c,sale_Saracl s
    WHERE c.custid = s.custid 
    GROUP BY (s.qty,s.custid) 
    HAVING AVG(s.sellprice) > (
      SELECT MIN(AVG(price)) 
      FROM  product_Saracl 
      WHERE pname LIKE 'FA%'
      GROUP BY price
    );

这些是表格:

    CREATE TABLE CUSTOMER_SaraCL( 
    
        CustID         NUMBER(8) NOT NULL,FirsT_NAME     VARCHAR2(15),SURNAME     VARCHAR2(15),ADDRESS     VARCHAR2(20),PHONE_NUMBER NUMBER(12)) 
    
        CLUSTER CUST_SALESaraCL(CustID); 
    
    CREATE TABLE PRODUCT_SaraHCL( 
    
        ProdID     NUMBER(10) NOT NULL,PName    Varchar2(6),PDesc    Varchar2(15),Price    Number(8),QOH        Number(5))
    
    CREATE TABLE SALE_SaraCL( 
    
        SaleID     NUMBER(10) NOT NULL,SaleDate    DATE,Qty            Number(5),SellPrice    Number(10),CustID        NUMBER(8),ProdID        NUMBER(10)) 
    
        CLUSTER CUST_SALESaraCL(CustID); 

我正在使用的索引:

    CREATE INDEX customer_index ON CUSTOMER_Saracl(custid);

查看执行计划时,添加任何提示时它不会改变一位,这就是我遇到的问题。

使用USE_MERGE提示查询计划:

Plan

这是查询上带有使用合并提示自动跟踪结果的粘贴框:https://pastebin.pl/view/b72a9a9d

谢谢大家!

解决方法

除非使用custid进行过滤(我对此表示怀疑),否则不需要“连接”。您可能会通过以下方式获得更好的执行计划:

SELECT AVG(s.sellprice),s.qty,s.custid  
FROM sale_saracl s
GROUP BY (s.qty,s.custid) 
HAVING AVG(s.sellprice) > (SELECT MIN(AVG(ps.price)) 
                           FROM product_saracl ps
                           WHERE ps.pname LIKE 'FA%'
                           GROUP BY price
                          );

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。