是否存在删除语句批处理过程中的运算符?

时间:2019-11-01 09:03:57

标签: oracle exists

我想知道流程的顺序,先执行什么..
 首先,我创建表=>

SQL> create table ramin.tab001 ( id number, name varchar2(20));
Table created.
    SQL> select *from ramin.tab001;

        ID NAME
---------- --------------------
         1 kamran
         2 emin
         3 ramin
         4 john

此后,我在选项=>

上使用了带有自动跟踪功能的相关子查询
SQL>delete from ramin.tab001 a where exists( select * from ramin.tab001 where id = a.id );

执行计划=>

Execution Plan
----------------------------------------------------------
Plan hash value: 906765530

------------------------------------------------------------------------------
| Id  | Operation           | Name   | Rows  | Bytes | Cost (%CPU)| Time     |
------------------------------------------------------------------------------
|   0 | DELETE STATEMENT    |        |     6 |    36 |     6   (0)| 00:00:01 |
|   1 |  DELETE             | TAB001 |       |       |            |          |
|*  2 |   HASH JOIN SEMI    |        |     6 |    36 |     6   (0)| 00:00:01 |
|   3 |    TABLE ACCESS FULL| TAB001 |     6 |    18 |     3   (0)| 00:00:01 |
|   4 |    TABLE ACCESS FULL| TAB001 |     6 |    18 |     3   (0)| 00:00:01 |
------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   2 - access("ID"="A"."ID")


Statistics
----------------------------------------------------------
          0  recursive calls
          7  db block gets
          6  consistent gets
          0  physical reads
       1204  redo size
        848  bytes sent via SQL*Net to client
       1005  bytes received via SQL*Net from client
          3  SQL*Net roundtrips to/from client
          1  sorts (memory)
          0  sorts (disk)
          4  rows processed

我知道在相关子查询中,处理顺序为=>
1.执行内部查询
2.执行外部查询并与内部查询的结果进行比较
因此,我需要专家对语句中的处理顺序或如何从自动跟踪中进行检查的意见?

1 个答案:

答案 0 :(得分:0)

如何阅读执行计划?

答案很简单。就像用命令式语言阅读多层嵌套的函数调用一样,阅读它。

例如,您的执行计划

------------------------------------------------------------------------------
| Id  | Operation           | Name   | Rows  | Bytes | Cost (%CPU)| Time     |
------------------------------------------------------------------------------
|   0 | DELETE STATEMENT    |        |     6 |    36 |     6   (0)| 00:00:01 |
|   1 |  DELETE             | TAB001 |       |       |            |          |
|*  2 |   HASH JOIN SEMI    |        |     6 |    36 |     6   (0)| 00:00:01 |
|   3 |    TABLE ACCESS FULL| TAB001 |     6 |    18 |     3   (0)| 00:00:01 |
|   4 |    TABLE ACCESS FULL| TAB001 |     6 |    18 |     3   (0)| 00:00:01 |
------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   2 - access("ID"="A"."ID")

可以简单地读取(以命令式伪代码的形式)

delete(
    from: "TAB001",
    data_set_to_be_deleted: semi_join(
        join_algorithm: "hash join",
        leading_data_set: table_access(
            read_access_method: "full",
            table_name: "TAB001"
        ),
        trailing_data_set: table_access(
            read_access_method: "full",
            table_name: "TAB001",
            aliased_as: "A"
        ),
        join_condition: "ID = A.ID"
    )
)