zoukankan      html  css  js  c++  java
  • SQL执行计划Cost与性能之间的的关系

    关于执行计划Cost的三个疑问:

    1. 执行计划的Cost越低,SQL就一定跑得越快吗?或者说Cost 和 执行时间成比例关系吗?

    2. Oracle 默认产生的执行计划是Cost最低的吗?

    3. 如果对象的统计信息都是最新的,执行计划就一定是准确和最优的吗?

    实践出真知:

    发现一条SQL,跑很久也没结果出来。

    SQL不是很长,但是执行计划很长。

    SQL文本:

    SELECT TO_CHAR(SYSDATE, 'yyyy-mm-dd') AS STAT_DATE,
           SYSDATE AS STAT_TIME,
           X.TABLE_NAME,
           NVL(X.NUM_ROWS, 0) AS TABLE_ROWS,
           NVL(ROUND(X.NUM_ROWS * X.AVG_ROW_LEN / 1024, 2), 0) AS TABLE_SIZES,
           Y.CREATED AS CREATE_TIME,
           Z.COMMENTS AS TABLE_COMMENT,
           H .COL_CNT
      FROM ALL_TABLES X,
           ALL_OBJECTS Y,
           ALL_TAB_COMMENTS Z,
           (SELECT H .TABLE_NAME, COUNT(1) AS COL_CNT
              FROM ALL_TAB_COLS H
             WHERE H.OWNER = 'TOSSKA'
             GROUP BY H .TABLE_NAME) H
     WHERE X.TABLE_NAME = Y.OBJECT_NAME
       AND X.TABLE_NAME(+) = Z.TABLE_NAME
       AND X.TABLE_NAME = H.TABLE_NAME
       AND Y.OBJECT_TYPE IN ('TABLE PARTITION', 'TABLE')
       AND X. OWNER = 'TOSSKA'
       AND Y. OWNER = 'TOSSKA'
       AND Z. OWNER = 'TOSSKA'
     ORDER BY X.TABLE_NAME

     执行计划:

       执行计划有214个步骤。太长了影响阅读,这里只显示小部分执行计划,大约十分之一吧。

    在 Tosska SQL Tuning Expert for Oracle 中输入SQL,点击Tune开始自动优化。

    一边喝咖啡, 一边等待… 

    优化结束后,工具帮我找到了5条更快的等价SQL. 

    有兴趣的朋友,可以将SQL中的OWNER从TOSSKA改为自己数据库上的用户名(用户下要有大量的表,否则SQL没有返回结果集,看不出效果),亲自试一试。  

    让我们来分析下6条SQL(原SQL,5条优化后更快的SQL) 执行计划Cost和性能之间的关系。

    下图可以看出来,Cost和SQL执行时间并不成比例关系。

    仔细观察原SQL和优化后的SQL,我们来回答博客开头提出的三个问题。

    1. SQL 127 和 SQL 129 的Cost比原始SQL高很多,大约是原始SQL的3倍,但是速度却比原始SQL快很多。换句话说,Cost只是估计值,和真实的速度没有直接关系。
    2. 原始SQL的Cost是1330, 等价SQL 130, SQL 135 和 SQL 45的Cost 都比原始SQL低。然而Oracle并没有选中这些Cost更低的执行计划。 换句话说,Cost低的执行计划漏选了。Oracle并没有错,SQL优化器不能遍历所有执行计划,然后找出Cost最低的执行计划;否则寻找Cost最低的执行计划所耗费的时间,可能会超过SQL执行所需要的时间, 得不偿失。
    3. CBO 是基于对象的统计信息,根据一堆公式估算执行计划成本和返回行数的,难免会出现误差;当误差级联放大之后,就可能导致产生次优或者不好的执行计划;这也是Oracle推出Adaptive Plan的一个原因;

    Oracle是目前最强大的数据库,但是优化潜力依然巨大, 这也是众多SQL优化专家和优化工具的价值所在。

    感受SQL优化工具的魅力,分享SQL优化故事…

    SQL 优化工具下载:

    https://www.tosska.cn/tosska-sql-tuning-expert-tse-oracle-free-download-zh/

    SQL优化工具,让您节省时间,专注公司业务
  • 相关阅读:
    Linux下如何查看版本信息
    SUSE12Sp3安装配置.net core 生产环境(2)-安装.NET Core 2.2.1 runtime 并运行.NET代码
    NET CORE Learning
    JWT(JSON Web Token)原理简介
    定性分析与定量分析的异同及优缺点
    《React16免费基础视频教程》【2】
    《React16免费基础视频教程》【1】
    《狂神说-JUC》【3】
    《狂神说-JUC》【2】
    《狂神说-JUC》【1】
  • 原文地址:https://www.cnblogs.com/dbexpert/p/10318550.html
Copyright © 2011-2022 走看看