union all 以及标量子查询执行计划

SELECT 1, (SELECT ID1 FROM TE WHERE ID=A.ID2)

FROM .TA A

WHERE COLA= 'X' UNION ALL

SELECT 1, (SELECT ID2 FROM TD WHERE ID=A.ID1)

FROM .TB A

WHERE COLA= 'X' UNION ALL

SELECT 1,COL2 AS PARENT_UUID FROM .TC a

WHERE COLA= 'X'

三个union all 看着像是5个table join,其实有两个是子查询,要反着看 2 3 4 5列的执行计划。


| Id | Operation | Name | Rows | Bytes | Cost | Time |


| 0 | SELECT STATEMENT | | 3 | 174 | 11 | 00:00:01 |

| 1 | UNION-ALL | | | | | |
| 2 | TABLE ACCESS BY GLOBAL INDEX ROWID BATCHED | TE | 1 | 34 | 3 | 00:00:01 |
| * 3 | INDEX RANGE SCAN | TE_PK | 1 | | 2 | 00:00:01 |
| 4 | PARTITION LIST SINGLE | | 1 | 29 | 2 | 00:00:01 |
| 5 | TABLE ACCESS FULL | TA | 1 | 29 | 2 | 00:00:01 |

| 6 | TABLE ACCESS BY GLOBAL INDEX ROWID BATCHED | TD | 1 | 34 | 2 | 00:00:01 |

| * 7 | INDEX RANGE SCAN | TD_PK | 1 | | 1 | 00:00:01 |

| 8 | PARTITION LIST SINGLE | | 1 | 29 | 2 | 00:00:01 |

| 9 | TABLE ACCESS FULL | TB | 1 | 29 | 2 | 00:00:01 |

| 10 | PARTITION LIST SINGLE | | 1 | 29 | 2 | 00:00:01 |

| 11 | TABLE ACCESS FULL | TC | 1 | 29 | 2 | 00:00:01 |


Predicate Information (identified by operation id):


* 3 - access("ID"=:B1)

* 7 - access("ID"=:B1)

相关推荐
pengdott1 小时前
Oracle RAC内存融合技术深度解析:集群性能的幕后引擎
数据库·oracle
csudata2 小时前
绿色便携版PostgreSQL发行版重磅发布
数据库·postgresql
阳光九叶草LXGZXJ2 小时前
达梦数据库-学习-48-DmDrs控制台命令(同步之Manager、CPT模块)
linux·运维·数据库·sql·学习
我科绝伦(Huanhuan Zhou)3 小时前
脚本再升级,兼容Oracle 26ai一键安装
数据库·oracle
野生绿箭侠3 小时前
Ncos 2.3.2 版本集成达梦数据库
数据库
仍然.4 小时前
MYSQL--约束
数据库·mysql
乡野码圣4 小时前
【RK3588 Android12】RCU机制
java·jvm·数据库
亓才孓4 小时前
[数据库]应该注意的细节
数据库·sql
m0_561359675 小时前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
xxxmine6 小时前
redis学习
数据库·redis·学习