Home » RDBMS Server » Performance Tuning » excessive parsing ? (DB SE2 19.3.0.0.0)
excessive parsing ? [message #685978] Fri, 13 May 2022 05:17 Go to next message
John Watson
Messages: 8963
Registered: January 2010
Location: Global Village
Senior Member
I have a performance issue that I think may be excessive parsing. It is a procedure that runs for close to three hours, and we need it to be under 10 minutes. In a statspack report for the run I see this,
Time Model System Stats  DB/Inst: redacted  Snaps: 292-296
-> Ordered by % of DB time desc, Statistic name

Statistic                                       Time (s) % DB time
----------------------------------- -------------------- ---------
sql execute elapsed time                        10,263.1     100.0
DB CPU                                           8,851.7      86.2
parse time elapsed                               6,982.6      68.0
hard parse elapsed time                          6,963.3      67.8
failed parse elapsed time                        3,471.2      33.8
hard parse (sharing criteria) elaps              3,410.1      33.2
PL/SQL execution elapsed time                      101.8       1.0
hard parse (bind mismatch) elapsed                   2.6        .0
PL/SQL compilation elapsed time                      1.8        .0
repeated bind elapsed time                           1.8        .0
RMAN cpu time (backup/restore)                       0.6        .0
connection management call elapsed                   0.0        .0
DB time                                         10,263.8
background elapsed time                            794.7
background cpu time                                 38.6
which I interpret as a massive hard parsing workload. I had enabled tracing in the session before running the rocedure with
exec dbms_monitor.session_trace_enable(waits=>true,binds=>true)
and in the tkprof output I see this for statement with the longest exeela,
SQL ID: brzrz3zut1yxp Plan Hash: 1635839828

SELECT redacted


call     count       cpu    elapsed       disk      query    current        rows
------- ------  -------- ---------- ---------- ---------- ----------  ----------
Parse    73799     87.46      89.74          0          0          0           0
Execute  73799   6049.57    6307.49          0   17715420          2           0
Fetch    73799    211.26     222.71          0    2361568          0       73799
------- ------  -------- ---------- ---------- ---------- ----------  ----------
total   221397   6348.30    6619.95          0   20076988          2       73799

Misses in library cache during parse: 73799
Misses in library cache during execute: 73799
Optimizer mode: ALL_ROWS
Parsing user id: 120     (recursive depth: 1)
Number of plan statistics captured: 73799

Rows (1st) Rows (avg) Rows (max)  Row Source Operation
---------- ---------- ----------  ---------------------------------------------------
redacted


Elapsed times include waiting on following events:
  Event waited on                             Times   Max. Wait  Total Waited
  ----------------------------------------   Waited  ----------  ------------
  PGA memory operation                            8        0.00          0.00
  latch: shared pool                              1        0.00          0.00
********************************************************************************
Is this telling me that the statement was executed 73799 times and that each time required a hard parse? If so, why?? Furthermore, the trace tells me that the parse took only 89.74 seconds, but statspack is telling me that 67.8% of the total DB Time was parsing; how can I reconcile these figures?

Thank you for any insight.

--update: a bit more information. In the Instance Activity Stats section of statspack, I see this
parse count (failures)                       147,602           14.3          2.0
parse count (hard)                           296,376           28.6          4.0
parse count (total)                        1,941,296          187.4         26.2
parse time cpu                                34,402            3.3          0.5
parse time elapsed                            31,822            3.1          0.4
which doesn't look too good. But again, I can't reconcile those figure with anything else.

[Updated on: Fri, 13 May 2022 05:32]

Report message to a moderator

Re: excessive parsing ? [message #685979 is a reply to message #685978] Fri, 13 May 2022 06:16 Go to previous messageGo to next message
John Watson
Messages: 8963
Registered: January 2010
Location: Global Village
Senior Member
And more: I see this at the end of my tkprof,
********************************************************************************

OVERALL TOTALS FOR ALL NON-RECURSIVE STATEMENTS

call     count       cpu    elapsed       disk      query    current        rows
------- ------  -------- ---------- ---------- ---------- ----------  ----------
Parse        2      0.00       0.00          0          0          0           0
Execute      3    401.60     415.47          0          0          0           3
Fetch        0      0.00       0.00          0          0          0           0
------- ------  -------- ---------- ---------- ---------- ----------  ----------
total        5    401.60     415.47          0          0          0           3

Misses in library cache during parse: 1

Elapsed times include waiting on following events:
  Event waited on                             Times   Max. Wait  Total Waited
  ----------------------------------------   Waited  ----------  ------------
  SQL*Net message to client                       2        0.00          0.00
  SQL*Net message from client                     2      182.67        182.67
  PGA memory operation                            2        0.00          0.00
  log file sync                                   1        0.00          0.00


OVERALL TOTALS FOR ALL RECURSIVE STATEMENTS

call     count       cpu    elapsed       disk      query    current        rows
------- ------  -------- ---------- ---------- ---------- ----------  ----------
Parse   1918847    338.00     304.00          0          0          2           0
Execute 4588680   7692.04    9075.18          0   18971458    1287557      222016
Fetch   4441053    970.24     860.95          0  103596595          0     4497753
------- ------  -------- ---------- ---------- ---------- ----------  ----------
total   10948580   9000.29   10240.15          0  122568053    1287559     4719769

Misses in library cache during parse: 221450
Misses in library cache during execute: 73850
I also see this in the statspack,
Library Cache Activity  DB/Inst: ITRKDEV/itrkdev  Snaps: 292-296
->"Pct Misses"  should be very low

                         Get  Pct        Pin        Pct               Invali-
Namespace           Requests  Miss     Requests     Miss     Reloads  dations
--------------- ------------ ------ -------------- ------ ---------- --------
AUDIT POLICY               8    0.0              8    0.0          0        0
BODY                   3,615    0.0         10,101    0.3         26        0
CLUSTER                   26    0.0             26    0.0          0        0
DBLINK                     9    0.0              0                 0        0
EDITION                  199    0.0            245    0.0          0        0
HINTSET OBJECT       811,800    0.0        811,800    9.1     73,800        0
INDEX                      1    0.0              1    0.0          0        0
OBJECT ID                  2  100.0              0                 0        0
SCHEMA                   633    0.0              0                 0        0
SQL AREA             153,080    0.5      6,412,585    9.2    295,398  295,211
SQL AREA BUILD       295,934    0.1              0                 0        0
SQL AREA STATS       295,843    0.2        295,843    0.2          0        0
TABLE/PROCEDURE      594,952    0.0      4,747,609    0.0         80        0
TRIGGER                  176    0.0            212    0.0          0        0
USER PRIVILEGE             2    0.0              2  100.0          2        0
          -------------------------------------------------------------
all those invalidations can't be right.
What might be going on?
Re: excessive parsing ? [message #685980 is a reply to message #685979] Sun, 15 May 2022 05:33 Go to previous message
John Watson
Messages: 8963
Registered: January 2010
Location: Global Village
Senior Member
I think I have the answer: dynamic sampling. This was set to 4, putting it back to the default of 2 (ie, it won't do any because all the objects do have stat's) has removed all that parsing completely. I find this worrying because previously I have always strongly recommended dynamic sampling at level 4. I have known this deliver dramatic benefits, and never (previously....) seen it cause a problem.
The process is now running in 25 minutes instead of 170, should be able to tune that down below 10 now Smile
Previous Topic: Re-Partitioning
Next Topic: query tunning
Goto Forum:
  


Current Time: Thu Jan 23 11:21:31 CST 2025