oracle语句执行效率
在ETL项目中遇到一个问题,同一sql语句,但是执行的时间却是天差地别,有时很快有时非常慢,这是有可能oralce在执行语句是自动对于sql 语句进行了调优,而我们手动调优的后,db又自动调优,时间就花在db的自动调优上,往往调优的还使执行变慢。
“sql 文本包含/SQL Analyze(5,0)/这样的信息通常是SQL Tuning Advisor调用的,这表明这个holder有可能运行了SQL Tuning Advisor,从trace中可以观察到holder(节点1的session532473)曾经parse过。。。”
关闭自动优化
SYS@db2> select client_name,status from DBA_AUTOTASK_CLIENT;
CLIENT_NAME STATUS
auto optimizer stats collection ENABLED
auto space advisor ENABLED
sql tuning advisor ENABLED
–禁用sql tuning advisor
SYS@db2> BEGIN
2 dbms_auto_task_admin.disable(
3 client_name => ‘sql tuning advisor’,
4 operation => NULL,
5 window_name => NULL);
6 END;
7 /
PL/SQL procedure successfully completed.
–再次查询状态
SYS@db2> select client_name,status from DBA_AUTOTASK_CLIENT;
CLIENT_NAME STATUS
auto optimizer stats collection ENABLED
auto space advisor ENABLED
sql tuning advisor DISABLED
–启用sql tuning advisor
BEGIN
dbms_auto_task_admin.enable(
client_name => ‘sql tuning advisor’,
operation => NULL,
window_name => NULL);
END;
参考https://www.linuxidc.com/Linux/2017-01/139270.htm