TKPROF输出中的开始数据是什么?

时间:2019-02-25 12:10:56

标签: oracle oracle12c database-administration

当我得到tkprof输出时,在执行计划区域中看到时间和成本数据之间的“ starts = 1”数据。那是什么意思?

基本上,这个区域:    (cr = 15 pr = 0 pw = 0时间= 514我们开始= 1 费用= 3大小= 7383卡= 107)

********************************************************************************

SQL ID: 7jk33n4f4mpy9 Plan Hash: 1445457117

select * 
from
 hr.employees


call     count       cpu    elapsed       disk      query    current        rows
------- ------  -------- ---------- ---------- ---------- ----------  ----------
Parse        1      0.04       0.03          0        351          0           0
Execute      1      0.00       0.00          0          0          0           0
Fetch        9      0.00       0.00          0         15          0         107
------- ------  -------- ---------- ---------- ---------- ----------  ----------
total       11      0.04       0.03          0        366          0         107

Misses in library cache during parse: 1
Optimizer mode: ALL_ROWS
Parsing user id: SYS
Number of plan statistics captured: 1

Rows (1st) Rows (avg) Rows (max)  Row Source Operation
---------- ---------- ----------  ---------------------------------------------------
       107        107        107  TABLE ACCESS FULL EMPLOYEES (cr=15 pr=0 pw=0 time=514 us starts=1 cost=3 size=7383 card=107)

********************************************************************************

1 个答案:

答案 0 :(得分:2)

STARTS是计划中该行开始的次数。使用(例如)联接时更容易看到。这是一个例子

SQL> select /*+ leading(d) use_nl(e) gather_plan_statistics */
  2         e.ename, d.dname
  3  from   scott.dept d,
  4         scott.emp e
  5  where  e.deptno = d.deptno
  6  and    e.sal > 1000;

ENAME      DNAME
---------- --------------
CLARK      ACCOUNTING
KING       ACCOUNTING
MILLER     ACCOUNTING
JONES      RESEARCH
SCOTT      RESEARCH
ADAMS      RESEARCH
FORD       RESEARCH
ALLEN      SALES
WARD       SALES
MARTIN     SALES
BLAKE      SALES
TURNER     SALES

12 rows selected.

SQL>
SQL> select * from table(dbms_xplan.display_cursor(null,null,'ALLSTATS LAST'));

PLAN_TABLE_OUTPUT
---------------------------------------------------------------------------------------
--------------------------------
SQL_ID  37nwzk5qypud3, child number 0
-------------------------------------
select /*+ leading(d) use_nl(e) gather_plan_statistics */
e.ename, d.dname from   scott.dept d,        scott.emp e where
e.deptno = d.deptno and    e.sal > 1000

Plan hash value: 4192419542

-------------------------------------------------------------------------------------
| Id  | Operation          | Name | Starts | E-Rows | A-Rows |   A-Time   | Buffers |
-------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |      |      1 |        |     12 |00:00:00.01 |      32 |
|   1 |  NESTED LOOPS      |      |      1 |     13 |     12 |00:00:00.01 |      32 |
|   2 |   TABLE ACCESS FULL| DEPT |      1 |      4 |      4 |00:00:00.01 |       7 |
|*  3 |   TABLE ACCESS FULL| EMP  |      4 |      3 |     12 |00:00:00.01 |      25 |
-------------------------------------------------------------------------------------

我们扫描了DEPT,得到了4行。然后针对这4行中的每行进行一次EMP全面扫描,因此第3行开始了 4次。