问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

道森oracle 优化 怎么样

发布网友 发布时间:2022-04-10 10:47

我来回答

2个回答

懂视网 时间:2022-04-10 15:08

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语句完整的执行顺序

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

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

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

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

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

6、计算所有的表达式;

7、select 的字段;

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

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

 

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

 

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

逻辑查询处理阶段简介:

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

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

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

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

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

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

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

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

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

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

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

 

2.  Oracle执行计划

2.1 执行顺序

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

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

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

 

 技术分享图片

 

 

图31 执行计划图

 

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

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

     

    2.2 RBO和CBO

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

    Oracle的优化器有两种:

  • RBO(Rule-Based Optimization) 基于规则的优化器
  • CBO(Cost-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 join、left join和right join

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

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

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

     

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

     

    Oracle优化学习

    标签:没有   sql   判断   添加   影响   strong   info   返回   统计   

    热心网友 时间:2022-04-10 12:16

    没听过道森的课程。不予评价
    学优化,前提是你深入理解oracle的内部原理。内部原理你懂了,就可以见招拆招,以不变应万变。
    你像去学优化案例什么的,都白扯,为什么这么说,因为大家普遍反映优化难,之所以难是因为它并没有模式可循,稍微一个地方改变,导致的结果就千变万化。
    你比如一个查询慢,因为某个等待事件。根据这个等待事件找到原因解决了。本身这个案例,你顶多学到几个等待事件。如果是别的等待事件呢,你又不知道什么原因了。
    所以学优化,不要学案例,要学就学内部原理,跟踪。学习DSI
    最后,个人给你推荐下一个网上培训的,“尖峰在线”,里面有个DSI课程。你可以去试听。因为我之前考ocp报过这个课程,非常不错,讲的很深入。很多东西想不通的都理解了。
    最后一点,我不是打广告的,就事论事。
    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    为什么来大姨妈胸会胀 少儿学什么舞蹈 青年学什么舞蹈好 成年人学什么舞蹈 福州企业最低工资标准 2013年厦门的底薪是多少 生产要素的需求有哪些性质 生产要素的需求有何特点? 什么是生产要素需求 微观经济学要素需求什么是条件要素需求?它和要素需求有什么不同?_百度... 去厦门旅游,都有什么好的建议?该如何避免被坑? 怎样说明自己想买的组装电脑配置? HP3159和HP3169的差别大吗? 深圳市方维达科技有限公司怎么样? 爷爷一定有办法读书卡图片 看了部片子涿州王建萍门事件,心情不好 opporeno2和oppoa5哪款手机好? 淘宝买的wifi怎么用 为什么淘宝只能在wifi下打开在流量下打不开 为什么我的淘宝在没有wifi的环境下用移动数据打不开呢? 机械师T58Windows10调节电脑分辨率的快捷键,我电脑开机变得很大,而且没有登录界面,求答案 手机淘宝为什么只有在wifi情况下才能打开 为什么我的手机淘宝在wifi状态下可用而在4G网络下不可用? 淘宝店铺里的视频,用手机为什么看不到? 肯定不是网速的原因,我用的是极速的wifi。 我家wifi能上淘宝,但看不了视频 设置了淘宝在wifi下不能用怎么设置回来 淘宝wifi怎么使用? 淘宝录制短视频是只能在WiFi情况下吗 快速降低分辨率快捷键 天猫手机无线端的详情页里面怎么添加上传视频?求详细方法,或者教程 准备和朋友去厦门旅游,去之前应该进行哪些准备呢? 都是本人实名认证过的也绑定银行卡为什么收款收不了转账也不能转_百度问一问 去厦门旅游需要准备什么吗? 去厦门旅游需要注意什么? 想去厦门,第一次去厦门要注意什么 外地去厦门旅游有什么要注意的吗,景点需要提前预约吗? 厦门旅游攻略--注意事项 javascript如何在打开新html时传递参数 去厦门旅游应该怎么安排? javascript+html 怎么实现一个html向新另一个HTML传值,可以吗?_百度... 去厦门旅游要准备什么?要注意什么?什么东西必须带的?谢谢 我和女友去的 html页面参数传递问题 javascript页面传参 接收参数 如何将html中的值传递给js html javascript的控件传递参数问题 关于javascript 在html中传值的问题 墨镜一带顺口溜全文是什么? 请问HTML中怎么向javascript中传递数组参数 在页面引用JAVASCRIPT时怎么给JAVASCRIPT传参 形容戴眼镜幽默句子有哪些?