As of 11gR2 Real Time SQL Monitoring also shows bind variable values used in the SQL statements.
data:image/s3,"s3://crabby-images/e5ad8/e5ad80540e00ad29300ac810d2e611ee904f6a49" alt=""
Monitoring could be enabled for any statement by adding the /*+ MONITOR */ hint. Thereafter when the statement runs Oracle will monitor the statement.
data:image/s3,"s3://crabby-images/105ad/105adde31a1818241077b5a91e4c21d309570d02" alt=""
However when there's no access to the SQL code this method of enabling monitoring is not possible. This is where dbms_sqltune.import_sql_profile comes in handy.
DBMS_SQLTUNE.IMPORT_SQL_PROFILE is an undocumented method which could be used to attache a profile to a SQL.
This is the test case to attache a monitoring profile to the sql to get the bind variables (11gR2) or/and enable monitoring (11gR1 and 11gR2).
SQL> variable var numberWhen the above select statement is executed SQL will appear in the real time monitoring.
SQL> exec :var := 10;
SQL> select * from x where b not in (select q from y where y.p = x.a) and x.a = :var;
A B
--- ------
10 75282
SQL> select sql_id from v$sql where sql_text like
'select * from x where b not in (select q from y where y.p = x.a) and x.a%';
SQL_ID
-------------
3nprf920bb7az
---- create the profile for the sql
Declare
Sqltext Clob;
Begin
Select Sql_Text Into Sqltext From V$sqlarea Where Sql_Id='3nprf920bb7az';
Dbms_Sqltune.Import_Sql_Profile(
Sql_Text => Sqltext,
Profile => Sqlprof_Attr('MONITOR'),
CATEGORY => 'DEFAULT',
Name => 'monitor_profile',
Force_Match => True);
End;
/
SQL> select * from x where b not in (select q from y where y.p = x.a) and x.a = :var;
data:image/s3,"s3://crabby-images/e2d3e/e2d3e82379e9c0d011f0199a07ba63c868b2d346" alt=""
Once done drop the profile with
exec dbms_sqltune.DROP_SQL_PROFILE('monitor_profile');Profile could be attached to update statements as well but monitoring window does not show the bind variables values.
SQL> variable a number;SQL Monitoring shows the following for the update statement
SQL> variable b number;
SQL> exec :a := 10;
SQL> exec :b := 20;
SQL> update vartable set a = :a * :b;
SQL> commit;
SQL> select sql_id from v$sqlarea where sql_text like 'update vartable set a = :a * :b';
SQL_ID
-------------
1g2mxvhws6a3x
Declare
Sqltext Clob;
Begin
Select Sql_Text Into Sqltext From V$sqlarea Where Sql_Id='1g2mxvhws6a3x';
Dbms_Sqltune.Import_Sql_Profile(
Sql_Text => Sqltext,
Profile => Sqlprof_Attr('MONITOR'),
CATEGORY => 'DEFAULT',
Name => 'monitor_profile',
Force_Match => True);
End;
/
SQL> update vartable set a = :a * :b;
5 rows updated.
data:image/s3,"s3://crabby-images/fd6b5/fd6b560ecd80746fefa20c8c2b5adf0735343b0a" alt=""
For insert statments attaching profile has no effect and they do not show up on the SQL Monitoring unless /*+ Monitor */ hint is used.
SQL> insert /*+ monitor */ into vartable values (:a,:b);
1 row created.
SQL> commit;
data:image/s3,"s3://crabby-images/4961f/4961f9634bb7e2d5ab7166b29c5d064beff9a679" alt=""