Changing Execution Plan of SQL Statement
To change execution plan of the sql statement. Collect the AWR report and find out the SQL_ID. Create SQL Tuning set between the snapshots generated by database using SQL_ID
Creating STS from AWR info
declare
cursor1 sys_refcursor
begin
open cursor1 for
select value(P)
from table(
dbms_sqltune.select_workload_repository(begin_snao=>34,end_snap=>35,
basic_filter=>’sql_id=''oraclewinning''',attribute_list=>'ALL')P;
dbms_sqltune.load_sqlset(sqlset_name=>'myfirstset',populate_cursor=>'cursor1')
close cursor1;
end;
/
verify newly created sql tuning contents
select * from table(dbms_sqltune.select_sqlset(sqlset_name=>'myfirstset'));
Loading desired plan from STS to SQL Plan Baseline
declare
best_plans pls_integer;
begin
best_plans :=dbms_spm.load_plans_from_sqlset(
sqlset_name=>'myfirstset',
basic_filter=>'plan_hash_value = ''oraclewinning''');
end;
/
when desired plan is loaded into the SQL PLAN BASELINE, In order to change the plan we have flush the current cursor in the library cache. We cab find existing cursor information with the help of SQL_ID
Find out sql_id of the existing sql in memory using v$sqlarea; Using v$sqlarea we can find out "sql_id" as follows
select sql_id, force_matching_signature, sql_text from v$sqlarea where SQL_TEXT like '%Select max%';
when desired plan is loaded into the SQL PLAN BASELINE, In order to change the plan we have flush the current cursor in the library cache. We cab find existing cursor information with the help of SQL_ID
Find out sql_id of the existing sql in memory using v$sqlarea; Using v$sqlarea we can find out "sql_id" as follows
select sql_id, force_matching_signature, sql_text from v$sqlarea where SQL_TEXT like '%Select max%';
using DBMS_XPLAN.DISPLAY_CURSOR we can find "sql_id" stored in memory
SQL>select * from TABLE(dbms_xplan.display_cursor('SQL_ID'));
Flush the cache from memory and using dbms_shared_pool.purge
--Finally we can re-run sql- statements and check execution time / plan of the sql statements