执行计划执行顺序
来源:互联网 发布:五轴加工中心编程软件 编辑:程序博客网 时间:2024/04/28 17:07
先从最开头一直往右看,直到看到最右边的并列的地方,对于不并列的,靠右的先执行:对于并列的,靠上的先执行。
即并列的缩进块,从上往下执行,非并列的缩进块,从下往上执行。
如下示例:
Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE
1 0 NESTED LOOPS
2 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_HOST_BATCH_DTL'
3 2 INDEX (RANGE SCAN) OF 'XIE2TB_HOST_BATCH_DTL' (NON-UNIQUE)
4 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_BATCH_TRAN_CTRL'
5 4 INDEX (UNIQUE SCAN) OF 'SYS_C0034652' (UNIQUE)
不妨假设最右边的数据为行号,语句执行是按块进行的。
从上述执行计划的开头一直往右看,直到找到最右边并列的。也就是从SELECT STATEMENT开始往右找。
找到一级缩进块,只有一个,没有优先级可言,如下:
1 0 NESTED LOOPS
2 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_HOST_BATCH_DTL'
3 2 INDEX (RANGE SCAN) OF 'XIE2TB_HOST_BATCH_DTL' (NON-UNIQUE)
4 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_BATCH_TRAN_CTRL'
5 4 INDEX (UNIQUE SCAN) OF 'SYS_C0034652' (UNIQUE)
再在一级缩进块中找二级缩进块,找到两个,如下:
第一个二级缩进块:
2 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_HOST_BATCH_DTL'
3 2 INDEX (RANGE SCAN) OF 'XIE2TB_HOST_BATCH_DTL' (NON-UNIQUE)
第二个二级缩进块:
4 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_BATCH_TRAN_CTRL'
5 4 INDEX (UNIQUE SCAN) OF 'SYS_C0034652' (UNIQUE)
按照并列块从上往下执行的原则,第一个二级缩进块的所有语句将优先于第二个二级缩进块的语句执行。
而两个二级缩进块执行完,才能执行一级缩进块,这是因为非并列的缩进块,从下往上执行。
再在二级缩进块中找三级缩进块。
第一个二级缩进块中只有一个三级缩进块,如下:
3 2 INDEX (RANGE SCAN) OF 'XIE2TB_HOST_BATCH_DTL' (NON-UNIQUE)
由于没有更低层级的缩进块,因此,该块最先执行。然后执行二级缩进块。
第二个二级缩进块中也只有一个三级缩进块,如下:
5 4 INDEX (UNIQUE SCAN) OF 'SYS_C0034652' (UNIQUE)
二级缩进块中没有更低层次的缩进块了,因此,执行完第一个二级缩进块的所有语句后,便执行此三级缩进块,再执行对应的二级缩进块。
两个二级缩进块均执行完成后,再执行整个一级缩进块。
因此,若按行排序,语句的执行顺序便是: 3 -> 2 -> 5 -> 4 -> 1, 即:
3 2 INDEX (RANGE SCAN) OF 'XIE2TB_HOST_BATCH_DTL' (NON-UNIQUE) ->
2 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_HOST_BATCH_DTL' ->
5 4 INDEX (UNIQUE SCAN) OF 'SYS_C0034652' (UNIQUE) ->
4 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_BATCH_TRAN_CTRL' ->
1 0 NESTED LOOPS
执行计划顺序的理论解释:
执行计划是按一定规则显示的,如下:
Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE
1 0 NESTED LOOPS
2 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_HOST_BATCH_DTL'
3 2 INDEX (RANGE SCAN) OF 'XIE2TB_HOST_BATCH_DTL' (NON-UNIQUE)
4 1 TABLE ACCESS (BY INDEX ROWID) OF 'TB_BATCH_TRAN_CTRL'
5 4 INDEX (UNIQUE SCAN) OF 'SYS_C0034652' (UNIQUE)
第一个列是步骤的ID (相当于我们说的行号)
第二个列是父步骤的ID
第三个列是该步骤要进行的操作。
在执行过程中,父步骤依赖于子步骤。只有对应的所有子步骤执行完,才能执行父步骤。
因此,步骤0的子步骤为1, 步骤1的子步骤为2,4, 步骤2子步骤为3,步骤4的子步骤为5, 步骤3,5没有子步骤了。
故步骤3所在的模块,或步骤5所在的模块先执行。但步骤3排在步骤5的前面,故步骤3所在的模块先执行。因此,顺序仍是:
3 -> 2 -> 5 -> 4 -> 1
转自:http://lanmh.iteye.com/blog/870563
- 执行计划执行顺序
- 执行计划和执行顺序
- 执行计划显示执行顺序
- 看懂执行计划 顺序
- oracle 执行计划和执行顺序
- oracle执行计划的执行顺序
- ORACLE执行计划的步骤和顺序
- ORACLE执行计划的步骤和顺序
- ORACLE数据库SQL优化--->如何执行计划的执行顺序
- SQL优化【基础02】 - 执行计划的执行先后顺序
- 执行计划
- 计划、执行
- 执行计划
- 执行计划
- 计划,,,执行
- 执行计划
- 执行计划
- 执行计划
- 数字滤波算法
- git客户/服务器配置
- 全息透玻璃交互式触摸显示器
- unity的一些特殊目录
- Python冒泡算法精讲<二>
- 执行计划执行顺序
- 理清文本编码
- 引发类型为“System.OutOfMemoryException”的异常。 遍历DataGridView 获取行错误
- Invalid signature file digest for manifest main attributes
- Duilib中使用TeeChart Pro v8(or手动添加ActiveX控件)
- 自动点击弹出框的“取消”按钮(初始化磁盘时,会弹出这样的窗口)
- 基于WOSA/XFS标准的金融开发
- OC 分类
- 非递归排序