• Oracle优化学习


    SQL执行效率对系统使用有很大影响,本文总结平时排查问题中遇到的一些Oracle优化问题的解决方案,或者日常学习所得。

    1. Oracle sql执行顺序

    sql语法的分析是从右到左。

    1.1 SQL语句的执行步骤

    1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义。

    2)语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限。

    3)视图转换,将涉及视图的查询语句转换为相应的对基表查询语句。

    4)表达式转换, 将复杂的 SQL 表达式转换为较简单的等效连接表达式。

    5)选择优化器,不同的优化器一般产生不同的“执行计划”

    6)选择连接方式, ORACLE 有三种连接方式,对多表连接 ORACLE 可选择适当的连接方式。

    7)选择连接顺序, 对多表连接 ORACLE 选择哪一对表先连接,选择这两表中哪个表做为源数据表。

    8)选择数据的搜索路径,根据以上条件选择合适的数据搜索路径,如是选用全表搜索还是利用索引或是其他的方式。

    9)运行“执行计划”

    1.2 SQL Select语句完整的执行顺序

    1from子句组装来自不同数据源的数据;

    2where子句基于指定的条件对记录行进行筛选;

    3group by子句将数据划分为多个分组;

    4、使用聚集函数进行计算;

    5、使用having子句筛选分组;

    6、计算所有的表达式;

    7select 的字段;

    8、使用order by对结果集进行排序。

    SQL语言不同于其他编程语言的最明显特征是处理代码的顺序。在大多数据库语言中,代码按编码顺序被处理。但在SQL语句中,第一个被处理的子句式FROM,而不是第一出现的SELECTSQL查询处理的步骤序号:

    1  (8)SELECT  (9) DISTINCT (11)  

    2  (1)  FROM  

    3  (3) JOIN  

    4  (2) ON  

    5  (4) WHERE  

    6  (5) GROUP BY  

    7  (6) WITH {CUBE | ROLLUP}

    8  (7) HAVING  

    9 (10) ORDER BY

    以上每个步骤都会产生一个虚拟表,该虚拟表被用作下一个步骤的输入。这些虚拟表对调用者(客户端应用程序或者外部查询)不可用。只有最后一步生成的表才会会给调用者。如果没有在查询中指定某一个子句,将跳过相应的步骤。

    逻辑查询处理阶段简介:

    1FROM:对FROM子句中的前两个表执行笛卡尔积(交叉联接),生成虚拟表VT1

    2ON:对VT1应用ON筛选器,只有那些使为真才被插入到TV2

    3OUTER (JOIN):如果指定了OUTER JOIN(相对于CROSS JOININNER JOIN),保留表中未找到匹配的行将作为外部行添加到VT2,生成TV3。如果FROM子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤1到步骤3,直到处理完所有的表位置。

    4WHERE:对TV3应用WHERE筛选器,只有使为true的行才插入TV4

    5GROUP BY:按GROUP BY子句中的列列表对TV4中的行进行分组,生成TV5

    6CUTE|ROLLUP:把超组插入VT5,生成VT6

    7HAVING:对VT6应用HAVING筛选器,只有使为true的组插入到VT7

    8SELECT:处理SELECT列表,产生VT8

    9DISTINCT:将重复的行从VT8中删除,产品VT9

    10ORDER BY:将VT9中的行按ORDER BY子句中的列列表顺序,生成一个游标(VC10)

    11TOP:从VC10的开始处选择指定数量或比例的行,生成表TV11,并返回给调用者。

    2.  Oracle执行计划

    2.1 执行顺序

    根据Operation缩进来判断,缩进最多的最先执行;(缩进相同时,最上面的最先执行)

    同一级如果某个动作没有子ID就最先执行

    同一级的动作执行时遵循最上最右先执行的原则

     

    31 执行计划图

    表访问的几种方式:(非全部)

    • TABLE ACCESS FULL(全表扫描)
    • TABLE ACCESS BY ROWID(通过ROWID的表存取)
    • TABLE ACCESS BY INDEX SCAN(索引扫描)

    2.2 RBOCBO

    Oracle中的优化器是SQL分析和执行的优化工具,它负责生成、制定SQL的执行计划。

    Oracle的优化器有两种:

    • RBORule-Based Optimization) 基于规则的优化器
    • CBOCost-Based Optimization) 基于代价的优化器

    RBO

    RBO有严格的使用规则,只要按照这套规则去写SQL语句,无论数据表中的内容怎样,也不会影响到你的执行计划;

    换句话说,RBO对数据不敏感,它要求SQL编写人员必须要了解各项细则;

    RBO一直沿用至ORACLE 9i,从ORACLE 10g开始,RBO已经彻底被抛弃。

    CBO

    CBO是一种比RBO更加合理、可靠的优化器,在ORACLE 10g中完全取代RBO

    CBO通过计算各种可能的执行计划的代价,即COST,从中选用COST最低的执行方案作为实际运行方案;

    它依赖数据库对象的统计信息,统计信息的准确与否会影响CBO做出最优的选择,也就是对数据敏感

    2.3 inner joinleft joinright join

    inner join 内连接,只返回两边相等数据。

    left join 左连接,以左边为基本表返回数据,右表匹配。

    right join右连接,已右边为基本表返回数据,左表匹配。

    使用左右连接时注意别把on后条件放到where 后,不然会等同于内连接了。

  • 相关阅读:
    SpringBoot集成Swagger2并配置多个包路径扫描
    SpringBoot基于EasyExcel解析Excel实现文件导出导入、读取写入
    SpringBoot + SpringSecurity + Quartz + Layui实现系统权限控制和定时任务
    Redis数据持久化(RDB、AOF)
    so安全编译选项(栈溢出保护)
    Python调用Chrome下载文件
    AtomicInteger如何保证线程安全以及乐观锁/悲观锁的概念
    SpringCloud:Eureka的健康检测机制
    共享锁(S锁)和排它锁(X锁)
    Collection接口及其常用子类(java.util包)
  • 原文地址:https://www.cnblogs.com/Joy-Hu/p/8297945.html
Copyright © 2020-2023  润新知