在使用視圖或嵌套視圖的查詢語句中,Oracle 為了取得最優的執行計畫會將這些視圖進行合并,將視圖中的表與外部查詢的表進行串連。
- --樣本:
- SQL> select e.first_name, e.last_name, dept_locs_v.street_address, dept_locs_v.postal_code
- 2 from employees e,
- 3 (select d.department_id, d.department_name, l.street_address, l.postal_code
- 4 from departments d, locations l
- 5 where d.location_id = l.location_id) dept_locs_v
- 6 where dept_locs_v.department_id = e.department_id
- 7 and e.last_name = 'Smith';
-
- 執行計畫
- ----------------------------------------------------------
- Plan hash value: 994428606
-
- ---------------------------------------------------------------------------------------------
- | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
- ---------------------------------------------------------------------------------------------
- | 0 | SELECT STATEMENT | | 1 | 56 | 4 (0)| 00:00:01 |
- | 1 | NESTED LOOPS | | 1 | 56 | 4 (0)| 00:00:01 |
- | 2 | NESTED LOOPS | | 1 | 25 | 3 (0)| 00:00:01 |
- | 3 | TABLE ACCESS BY INDEX ROWID| EMPLOYEES | 1 | 18 | 2 (0)| 00:00:01 |
- |* 4 | INDEX RANGE SCAN | EMP_NAME_IX | 1 | | 1 (0)| 00:00:01 |
- | 5 | TABLE ACCESS BY INDEX ROWID| DEPARTMENTS | 1 | 7 | 1 (0)| 00:00:01 |
- |* 6 | INDEX UNIQUE SCAN | DEPT_ID_PK | 1 | | 0 (0)| 00:00:01 |
- | 7 | TABLE ACCESS BY INDEX ROWID | LOCATIONS | 1 | 31 | 1 (0)| 00:00:01 |
- |* 8 | INDEX UNIQUE SCAN | LOC_ID_PK | 1 | | 0 (0)| 00:00:01 |
- ---------------------------------------------------------------------------------------------
-
- Predicate Information (identified by operation id):
- ---------------------------------------------------
-
- 4 - access("E"."LAST_NAME"='Smith')
- 6 - access("E"."DEPARTMENT_ID"="D"."DEPARTMENT_ID")
- 8 - access("D"."LOCATION_ID"="L"."LOCATION_ID")
-
- --使用no_merge禁止視圖合并
- SQL> select /*+ no_merge(dept_locs_v)*/e.first_name, e.last_name, dept_locs_v.street_address, dept_locs_v.postal_code
- 2 from employees e,
- 3 (select d.department_id, d.department_name, l.street_address, l.postal_code
- 4 from departments d, locations l
- 5 where d.location_id = l.location_id) dept_locs_v
- 6 where dept_locs_v.department_id = e.department_id
- 7 and e.last_name = 'Smith';
-
- 執行計畫
- ----------------------------------------------------------
- Plan hash value: 842533999
-
- --------------------------------------------------------------------------------------------------
- | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
- --------------------------------------------------------------------------------------------------
- | 0 | SELECT STATEMENT | | 1 | 61 | 7 (15)| 00:00:01 |
- |* 1 | HASH JOIN | | 1 | 61 | 7 (15)| 00:00:01 |
- | 2 | TABLE ACCESS BY INDEX ROWID | EMPLOYEES | 1 | 18 | 2 (0)| 00:00:01 |
- |* 3 | INDEX RANGE SCAN | EMP_NAME_IX | 1 | | 1 (0)| 00:00:01 |
- | 4 | VIEW | | 27 | 1161 | 4 (0)| 00:00:01 |
- | 5 | TABLE ACCESS BY INDEX ROWID| DEPARTMENTS | 1 | 7 | 1 (0)| 00:00:01 |
- | 6 | NESTED LOOPS | | 27 | 1026 | 4 (0)| 00:00:01 |
- | 7 | TABLE ACCESS FULL | LOCATIONS | 23 | 713 | 3 (0)| 00:00:01 |
- |* 8 | INDEX RANGE SCAN | DEPT_LOCATION_IX | 4 | | 0 (0)| 00:00:01 |
- --------------------------------------------------------------------------------------------------
-
- Predicate Information (identified by operation id):
- ---------------------------------------------------
-
- 1 - access("DEPT_LOCS_V"."DEPARTMENT_ID"="E"."DEPARTMENT_ID")
- 3 - access("E"."LAST_NAME"='Smith')
- 8 - access("D"."LOCATION_ID"="L"."LOCATION_ID")