Programmatically or intercepted by forced cursor sharing, sql where clause actual values shall always be bound to variable placeholders and never / no longer be literally coded. You know Tom Kyte talking that story on each and every occasion, pointing out that so many sql areas got stuck in size and performance because of literal values and the resulting multitude of variants of sql statements. On the other hand, people complain about the sporadic issue that the optimizer takes wrong decisions due to one-time probing of actual values in a given session, a nightmare in 10g, much improved by adaptive cursor sharing throughout 12c meanwhile. Well, I do not want to dive into this again, what follows is just a commented recipe sql statement to inspect what actual bind values have had been in action for a (potentially) sub-optimal sql execution. Please note, that the STATISTICS_LEVEL
initialization parameter takes to be greater than BASIC
to have the statement deliver any data.
The statement is neither complex nor long-running, just using two perfomance views v$sql_bind_capture
and v$sqlarea
, resp. While v$sql_bind_capture
provides for the bind names, values, capture state and time, v$sqlarea
offers different ways to approach the subject, by schema or sql-id or module etc, and not at least, the raw text of the statement in question.
You must be logged in to post a comment.