日期:2014-05-16  浏览次数:20509 次

Oracle 数据库如何搜集指定SQL的执行计划和解决过程中的ORA-00904错误

Oracle 数据库如何搜集指定SQL的执行计划和解决过程中的ORA-00904错误

(版权声明,本人原创或者翻译的文章如需转载,如转载用于个人学习,请注明出处;否则请与本人联系,违者必究)

如何收集指定SQL的执行计划对开发人员来说非常重要的,这里记录下基础的收集方式,以便查阅和其他人参考。

1.      链接到sqlplus,如下图

2.      执行下面两个的命令之一

  set   autotrace   on; (说明:打开自动分析统计,并显示SQL语句的运行结果)  
  set   autotrace   traceonly; (说明:打开自动分析统计,不显示SQL语句的运行结果)

3.      输入并执行要搜集执行计划的SQL语句。

4.      这样执行计划就会打印出来。如上图

 

如果在收集的过程中遇到ORA-00904:"OTHER_TAG":标识符无效的问题,如下图

那么我们需要

1.      先drop掉表plan_table;

2.      使用@$ORACLE_HOME/rdbms/admin/utlxplan.sql重建plan_table;如下图


3.      重建完之后的搜集执行计划的效果如下。