SQL查询语句的性能从一定程度上影响整个数据库的性能。很多情况下,数据库性能的低下差不多都是不良SQL语句所引起。而SQL语句的执行 计划则决定了SQL语句将会采用何种方式从数据库提取数据并返回给客户端,本文描述的将是如何通过EXPLAIN PLAN 获取SQL语句执行计划来获 取SQL语句的执行计划。
一、获取SQL语句执行计划的方式
二、explain plan工作实质、前提及操作方法 1. 工作实质 将SQL语句预估的执行计划加载到表plan_table,是对表plan_table 执行了DML操作,故不会执行隐式提交 可以对select,insert,update,merge,delete,create table, create index,alter index等加载执行计划到plan_table
2. 前提条件 需要先创建plan_table,创建方法:@?/rdbms/admin/utlxplan 对当前的SQL语句有执行权限以及对依赖的对象有相应操作的权限
3. 使用方法: explain plan for select * from scott.emp where ename='SCOTT'; --未设置标记位 explain plan set statement_id='TEST' for select * from scott.emp where ename='SCOTT' --设置标记位为TEST