oracle怎样跟踪一条sql语句的执行过程?
就跟程序调试似的,可以把每个变量及中间结果都显示出来。感谢两位的回答,不过我想要的是跟踪SQL的执行循序,和中间结果。比如:selecta.id,b.namefromta...
就跟程序调试似的,可以把每个变量及中间结果都显示出来。
感谢两位的回答,不过我想要的是跟踪SQL的执行循序,和中间结果。
比如:select a.id,b.name
from tablename1 a
inner join tablename2 b
on a.id = b.id
where a.XX = b.YY
SQL可能写的不对,我想知道这个SQL语句是怎么执行的,比如,第一步执行from,确定数据源;第二步执行inner join ,第三步执行on确定连接条件,并且组织出一个视图(我这么理解的),这个视图的记录包含哪些。可能我说的步骤不对,不过我就是想知道这个一个过程!
小弟先谢谢各位大虾了,帮帮忙分析一下…… 展开
感谢两位的回答,不过我想要的是跟踪SQL的执行循序,和中间结果。
比如:select a.id,b.name
from tablename1 a
inner join tablename2 b
on a.id = b.id
where a.XX = b.YY
SQL可能写的不对,我想知道这个SQL语句是怎么执行的,比如,第一步执行from,确定数据源;第二步执行inner join ,第三步执行on确定连接条件,并且组织出一个视图(我这么理解的),这个视图的记录包含哪些。可能我说的步骤不对,不过我就是想知道这个一个过程!
小弟先谢谢各位大虾了,帮帮忙分析一下…… 展开
3个回答
展开全部
需要建立一张表来记录
explain plan SET statement_id='name' FOR (这里是你要调试的语句 )
SELECT
A.OPERATION,
OPTIONS,
OBJECT_NAME,
OBJECT_TYPE,
ID,
PARENT_ID
FROM
PLAN_TABLE A
WHERE
STATEMENT_ID='name'
ORDER BY
Id;
ID 'name'是一个标识,你可以自己取,字段有很多个,以下是各个字段的解释(可能格式不对,你可以复制后看):
字段名 字段类型 含义
STATEMENT_ID VARCHAR2(30) explain PLAN 语句中所指定的最优STATEMENT_ID 参数值, 如果在EXPLAN PLAN语句中没有使用SET STATEMENT_ID,那么此值会被设为NULL。
REMARKS VARCHAR2(80) 与被解释规划的各步骤相关联的注释最长可达80 字节
OPERATION VARCHAR2(30) 各步骤所执行内部操作的名称在某条语侍举毕句所产生的第一行中该列的可能取值如下DELETE STATEMENT INSERT STATEMENT SELECT STATEMENT UPDATE STATEMENT
OPTIONS VARCHAR2(30) 对OPERATION 列中所描述操作的变种
OBJECT_NODE VARCHAR2(128) 用于访问对象的数据库链接database link 的名称对于使用并行执行的本地查询该列能够描述操作中输出的次序
OBJECT_OWNER VARCHAR2(30) 对于包含有表或索引的架构schema 给出其所有者的名称
OBJECT_NAME VARCHAR2(30) 表或索引的名称
OBJECT_INSTANCE INTEGER 根据对象出现在原始original 语句中的次序所给出的相应次序编号就原始的语句文本而论其处理顺序为自左至右自外向内景象扩张view
OBJECT_TYPE VARCHAR2(30) 用于提供对象描述性信息的修饰符例如索引的NON-UNIQUE
OPTIMIZER VARCHAR2(255) 当前优化程序的模式
ID INTEGER 分配给执行规划各步骤的编号
PARENT_ID INTEGER 对ID 步骤的输出进行操作的下一个执行步骤的ID
POSITION INTEGER 对于具有相同PARENT_ID 的步骤其老芹相应的处理次序
COST INTEGER 根据优化程序的基答早于开销的方法所估计出的操作开销值对于使用基于规则方法的语句该列为空该列值没有特定的测量单位它只是一个用于比较执行规划开销大小的权重值
CARDINALITY INTEGER 根据基于开销的方法对操作所访问行数的估计值
BYTES INTEGER 根据基于开销的方法对操作所访问字节的估计
=============================================
你按照我说的做,后面用
SELECT
*
FROM
PLAN_TABLE A
WHERE
STATEMENT_ID='name'
结果已经很清楚了,全部满足你的要求。
各列的具体含义上面已经给出。
explain plan SET statement_id='name' FOR (这里是你要调试的语句 )
SELECT
A.OPERATION,
OPTIONS,
OBJECT_NAME,
OBJECT_TYPE,
ID,
PARENT_ID
FROM
PLAN_TABLE A
WHERE
STATEMENT_ID='name'
ORDER BY
Id;
ID 'name'是一个标识,你可以自己取,字段有很多个,以下是各个字段的解释(可能格式不对,你可以复制后看):
字段名 字段类型 含义
STATEMENT_ID VARCHAR2(30) explain PLAN 语句中所指定的最优STATEMENT_ID 参数值, 如果在EXPLAN PLAN语句中没有使用SET STATEMENT_ID,那么此值会被设为NULL。
REMARKS VARCHAR2(80) 与被解释规划的各步骤相关联的注释最长可达80 字节
OPERATION VARCHAR2(30) 各步骤所执行内部操作的名称在某条语侍举毕句所产生的第一行中该列的可能取值如下DELETE STATEMENT INSERT STATEMENT SELECT STATEMENT UPDATE STATEMENT
OPTIONS VARCHAR2(30) 对OPERATION 列中所描述操作的变种
OBJECT_NODE VARCHAR2(128) 用于访问对象的数据库链接database link 的名称对于使用并行执行的本地查询该列能够描述操作中输出的次序
OBJECT_OWNER VARCHAR2(30) 对于包含有表或索引的架构schema 给出其所有者的名称
OBJECT_NAME VARCHAR2(30) 表或索引的名称
OBJECT_INSTANCE INTEGER 根据对象出现在原始original 语句中的次序所给出的相应次序编号就原始的语句文本而论其处理顺序为自左至右自外向内景象扩张view
OBJECT_TYPE VARCHAR2(30) 用于提供对象描述性信息的修饰符例如索引的NON-UNIQUE
OPTIMIZER VARCHAR2(255) 当前优化程序的模式
ID INTEGER 分配给执行规划各步骤的编号
PARENT_ID INTEGER 对ID 步骤的输出进行操作的下一个执行步骤的ID
POSITION INTEGER 对于具有相同PARENT_ID 的步骤其老芹相应的处理次序
COST INTEGER 根据优化程序的基答早于开销的方法所估计出的操作开销值对于使用基于规则方法的语句该列为空该列值没有特定的测量单位它只是一个用于比较执行规划开销大小的权重值
CARDINALITY INTEGER 根据基于开销的方法对操作所访问行数的估计值
BYTES INTEGER 根据基于开销的方法对操作所访问字节的估计
=============================================
你按照我说的做,后面用
SELECT
*
FROM
PLAN_TABLE A
WHERE
STATEMENT_ID='name'
结果已经很清楚了,全部满足你的要求。
各列的具体含义上面已经给出。
展开全部
跟踪语句的执行最带野族详细的是设置10046事件:
alter session set event "10046 trace name context forever ,level 12";
你的语句;
alter session set event "10046 trace name context off ";
然后到udump目录中打开日期最新的文件,里面有脊册详细你的语句执行情况
包括执行的哪些递归调用,逻辑读,物理读等待事件,绑蠢弊定变量的值......
alter session set event "10046 trace name context forever ,level 12";
你的语句;
alter session set event "10046 trace name context off ";
然后到udump目录中打开日期最新的文件,里面有脊册详细你的语句执行情况
包括执行的哪些递归调用,逻辑读,物理读等待事件,绑蠢弊定变量的值......
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你要知道的步骤按照owens1818的explain plan 的做法就能够知道了。
查看一个语句的执行步骤,也可以通过一些工具来看,比如toad,sqldeveloper,sqlplus (set autotrace on ) 等。那弯乎竖样看起来比直接查询plan_table直观一些,顷凳
不过确实不能知道每一步骤中具体的记录。具体的记录只要你知道了每一步做什么,你自己就能够想出来了埋大。
查看一个语句的执行步骤,也可以通过一些工具来看,比如toad,sqldeveloper,sqlplus (set autotrace on ) 等。那弯乎竖样看起来比直接查询plan_table直观一些,顷凳
不过确实不能知道每一步骤中具体的记录。具体的记录只要你知道了每一步做什么,你自己就能够想出来了埋大。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询