 
 
 
 
 
 
 
 
 
 
 
| SET AUTOTRACE OFF | No AUTOTRACE report is generated. This is the default. | 
| SET AUTOTRACE ON EXPLAIN | The AUTOTRACE report shows only the optimizer execution path. | 
| SET AUTOTRACE ON STATISTICS | The AUTOTRACE report shows only the SQL statement execution statistics. | 
| SET AUTOTRACE ON | The AUTOTRACE report includes both the optimizer execution path and the SQL statement execution statistics. | 
| SET AUTOTRACE TRACEONLY | Like SET AUTOTRACE ON, but suppresses the printing of the user's query output, if any. | 
![[*]](jump.gif) .
.
Each line of the Execution Plan has a sequential line number. SQL*Plus also displays the line number of the parent operation.
The Execution Plan consists of four columns displayed in the following order:
| Column Name | Description | 
| ID_PLUS_EXP | Shows the line number of each execution step. | 
| PARENT_ID_PLUS_EXP | Shows the relationship between each step and its parent. This column is useful for large reports. | 
| PLAN_PLUS_EXP | Shows each step of the report. | 
| OBJECT_NODE_PLUS_EXP | Shows the database links or parallel query servers used. | 
SQL> COLUMN PARENT_ID_PLUS_EXP NOPRINT
The default formats can be found in the site profile (for example, glogin.sql).
The Execution Plan output is generated using the EXPLAIN PLAN command. For information about interpreting the output of EXPLAIN PLAN, see the Oracle7 Server Tuning guide.
The client referred to in the statistics is SQL*Plus. SQL*Net refers to the generic process communication between SQL*Plus and the server, regardless of whether SQL*Net is installed.
You cannot change the default format of the statistics report.
For more information about the statistics and how to interpret them, see the Oracle7 Server Tuning guide.
Example 3-21 Tracing Statements for Performance Statistics and Query Execution Path
If the SQL buffer contains the following statement:
SQL> SELECT D.DNAME, E.ENAME, E.SAL, E.JOB 2 FROM EMP E, DEPT D 3 WHERE E.DEPTNO = D.DEPTNO
The statement can be automatically traced when it is run:
SQL> SET AUTOTRACE ON SQL> /
DNAME          ENAME             SAL JOB
-------------- ---------- ---------- ---------
ACCOUNTING     CLARK            2450 MANAGER
ACCOUNTING     KING             5000 PRESIDENT
ACCOUNTING     MILLER           1300 CLERK
RESEARCH       SMITH             800 CLERK
RESEARCH       ADAMS            1100 CLERK
RESEARCH       FORD             3000 ANALYST
RESEARCH       SCOTT            3000 ANALYST
RESEARCH       JONES            2975 MANAGER
SALES          ALLEN            1600 SALESMAN
SALES          BLAKE            2850 MANAGER
SALES          MARTIN           1250 SALESMAN
SALES          JAMES             950 CLERK
SALES          TURNER           1500 SALESMAN
SALES          WARD             1250 SALESMAN
14 rows selected.
Execution Plan
-----------------------------------------------------------
   0      SELECT STATEMENT Optimizer=CHOOSE
   1    0   MERGE JOIN
   2    1     SORT (JOIN)
   3    2       TABLE ACCESS (FULL) OF 'DEPT'
   4    1     SORT (JOIN)
   5    4       TABLE ACCESS (FULL) OF 'EMP'
Statistics
----------------------------------------------------------
        148  recursive calls
          4  db block gets
         24  consistent gets
          6  physical reads
         43  redo size
        591  bytes sent via SQL*Net to client
        256  bytes received via SQL*Net from client
          3  SQL*Net roundtrips to/from client
          2  sort (memory)
          0  sort (disk)
         14  rows processedNote: Your output may vary depending on the version of the server to which you are connected and the configuration of the server.
Example 3-22
Tracing Statements Without Displaying Query Data 
SQL> SET AUTOTRACE TRACEONLY
SQL> /
Execution Plan
-----------------------------------------------------------
   0      SELECT STATEMENT Optimizer=CHOOSE
   1    0   MERGE JOIN
   2    1     SORT (JOIN)
   3    2       TABLE ACCESS (FULL) OF 'DEPT'
   4    1     SORT (JOIN)
   5    4       TABLE ACCESS (FULL) OF 'EMP'
Statistics
-----------------------------------------------------------
          0  recursive calls
          4  db block gets
          2  consistent gets
          0  physical reads
          0  redo size
        599  bytes sent via SQL*Net to client
        256  bytes received via SQL*Net from client
          3  SQL*Net roundtrips to/from client
          2  sort (memory)
          0  sort (disk)
         14  rows processedThis option is useful when you are tuning a large query, but do not want to see the query report.
Example 3-23 Tracing Statements Using a Database Link
To trace a statement using a database link:
SQL> SET AUTOTRACE TRACEONLY EXPLAIN SQL> SELECT * FROM EMP@MY_LINK; Execution Plan ----------------------------------------------------------- 0 SELECT STATEMENT (REMOTE) Optimizer=CHOOSE 1 0 TABLE ACCESS (FULL) OF 'EMP' MY_LINK.DB_DOMAIN
The Execution Plan shows the table being accessed on line 1 is via the database link MY_LINK.DB_DOMAIN.
Lines marked with an asterisk (*) denote a parallel or remote operation. Each operation is explained in the second part of the report. See the Oracle7 Server Tuning guide for more information on parallel and distributed operations.
The second section of this report consists of three columns displayed in the following order:
| Column Name | Description | 
| ID_PLUS_EXP | Shows the line number of each execution step. | 
| OTHER_TAG_PLUS_EXP | Describes the function of the SQL statement in the OTHER_PLUS_EXP column. | 
| OTHER_PLUS_EXP | Shows the text of the query for the parallel server or remote database. | 
Note: You must have Oracle7, Release 7.3 or greater to view the second section of this report.
Example 3-24 Tracing Statements With Parallel Query Option
To trace a parallel query running the parallel query option:
SQL> CREATE TABLE T2_T1 (UNIQUE1 NUMBER) PARALLEL - > (DEGREE 6); Table created. SQL> CREATE TABLE T2_T2 (UNIQUE1 NUMBER) PARALLEL - > (DEGREE 6); Table created. SQL> CREATE UNIQUE INDEX D2_I_UNIQUE1 ON D2_T1(UNIQUE1); Index created. SQL> SET LONG 500 LONGCHUNKSIZE 500 SQL> SET AUTOTRACE ON EXPLAIN SQL> SELECT /*+ INDEX(B,D2_I_UNIQUE1) USE_NL(B) ORDERED - > */ COUNT (A.UNIQUE1) 2 FROM D2_T2 A, D2_T1 B 3 WHERE A.UNIQUE1 = B.UNIQUE1;
SQL*Plus displays the following output:
Execution Plan
-----------------------------------------------------------
   0      SELECT STATEMENT Optimizer=CHOOSE (Cost=1 
                           Card=263 Bytes=5786)
   1    0   SORT (AGGREGATE)
   2    1     NESTED LOOPS* (Cost=1 Card=263 Bytes=5785)
                                                     :Q8200
   3    2       TABLE ACCESS* (FULL) OF 'D2_T2'      :Q8200
   4    2       INDEX* (UNIQUE SCAN) OF 'D2_I_UNIQUE1'
                       (UNIQUE)                      :Q8200
   2 PARALLEL_TO_SERIAL  SELECT /*+ ORDERED NO_EXPAND 
                         USE_NL(A2) IN DEX(A2) PIV_SSF */ 
                         COUNT(A1.C0) FROM (SELECT/*+ 
                         ROWID(A3) */ A3."UNIQUE1" FROM 
                         "D2_T2" A3 WHERE ROWID BETWEEN :1 
                         AND :2) A1, "D2_T1" A2 WHERE 
                         A1.C0=A2."UNIQUE1"
   3 PARALLEL_COMBINED_WITH_PARENT
   4 PARALLEL_COMBINED_WITH_PARENTLine 0 of the Execution Plan shows the cost based optimizer estimates the number of rows at 263, taking 5786 bytes. The total cost of the statement is 1.
Lines 2, 3 and 4 are marked with asterisks, denoting parallel operations. For example, the NESTED LOOPS step on line 2 is a PARALLEL_TO_SERIAL operation. PARALLEL_TO_SERIAL operations execute a SQL statement to produce output serially. Line 2 also shows that the parallel query server had the identifier Q8200.
 
 
 
 
 
 
 
 
