问答文章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

我来回答

4个回答

懂视网 时间: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

    道森优化分为思路分析和改写方案两类,分析类似于发现问题,而改写就是解决问题。因此优化是个泛泛的说明,关键要看楼主更关注分析问题还是解决问题。


    以下是我的学习心得,冰山一角


    追问谢谢。这都是上课的内容吧,好实用

    热心网友 时间:2022-04-10 13:34

    你可以说落落是个十足的大db,不过优化还得跟他学,这货牛*。

    热心网友 时间:2022-04-10 15:09

    曾经的5只有1.2K 到了道森后猛涨到15K
    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    八月中国最凉快的地方 八月份哪里最凉快,去哪旅游好?美丽的地方 乱字同韵字是什么意思 华硕笔记本电脑触摸板怎么开笔记本电脑触摸板怎么开启和关闭_百度知 ... 陕西职务侵占案立案准则 结婚后我的恋情维系了十年,怎么做到的? 玉米仁子饭产自哪里 中国期货交易所的交易品种有哪些? 历史要怎么读,有啥诀窍 高中历史诀窍 你好,我手机是OPPO的我输入正确的WiFi密码连接不上? 手机号被对方加黑了,网络电话怎么还是打不通? 航天信息,开票软件上传设置地址对的测试 链接失败 对方给10086打电话拦截了网络电话,打不通了咋办? 学习强国中网络电话怎么打不通 汽车春联自吸式怎么用 如何检测弹性缓存Redis的连通性? 如何用Curl 来post xml 数据 安装MvBox5.0到桌面如何直接打开播放器播放详细介绍官网 蛋糕店一般都招什么人,额。。就是什么岗位 在西饼屋/蛋糕房工作 什么职位比较好点?工资相对高一点点。适合女生的 西点师和面点师有哪些职业岗位可以工作 西点、蛋糕行业有哪些岗位发展方向? 国外用支付宝付款,汇率怎么查? 新版支付宝怎么换算汇率 支付宝汇率换算方法介绍 射流泵是什么?原理、特点 反循环回转钻进的类型 船用喷射泵工作原理 射流自吸离心泵的工作原理 射流泵的简介 网络电话为什么打不通? i54590和i56400谁跟好。为什么? 选台式机,i5 6400和i5 4590 哪个u更好?为神马? i54590好还是i56400好? 英特尔6400好还是4590好 i5-4590和i5-6400哪个好 英特尔i5-6400和i5-4590那款要好点?? i5 4590和i5 6400 相对来说,i5 6400有什么优势 这两个配置哪个好?怎么i5 6400跑得分还没有i5 4590高? i5 4590 。和6400 6500不比核显 性能是不是差不多的 i5-3470,i5-4590,i5-6400,哪个好?好在哪里 现在英特尔处理器i5,4590和6400和6500散片,每一个要多少钱,各位大神,谁知道给说一下, CPUI56400和4950K哪个搭配1660ti显卡合适 玩绝地求生大逃杀i5-6400 gtx1060怎么调画质流畅又清晰,还有i5-4590 gtx960 怎么改win8开机密码头像,扫描人头的相片。 这是一个什么石头整个都是银灰色的 请问银色的石头是什么石? 银灰色石头夹杂着金色亮点 而且划在别的石头上的痕迹是呈暗红色 这是什么石头? 从地里挖出来,灰色的,表面一摸就有灰的是什么石头 我有一块石头特别重不知道是什么石头里面银灰色特别细不知道足什么石头?