问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

oracle怎样跟踪一条sql语句的执行过程?

发布网友 发布时间:2022-04-26 10:53

我来回答

3个回答

热心网友 时间:2022-04-08 19:38

需要建立一张表来记录
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'

结果已经很清楚了,全部满足你的要求。
各列的具体含义上面已经给出。

热心网友 时间:2022-04-08 20:56

跟踪语句的执行最详细的是设置10046事件:
alter session set event "10046 trace name context forever ,level 12";

你的语句;

alter session set event "10046 trace name context off ";

然后到ump目录中打开日期最新的文件,里面有详细你的语句执行情况
包括执行的哪些递归调用,逻辑读,物理读等待事件,绑定变量的值......

热心网友 时间:2022-04-08 22:31

你要知道的步骤按照owens1818的explain plan 的做法就能够知道了。
查看一个语句的执行步骤,也可以通过一些工具来看,比如toad,sqldeveloper,sqlplus (set autotrace on ) 等。那样看起来比直接查询plan_table直观一些,
不过确实不能知道每一步骤中具体的记录。具体的记录只要你知道了每一步做什么,你自己就能够想出来了。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
手机玻璃硬度是多少合适 ips屏幕硬度怎么样 手机硬度是什么意思? 2024年拼多多春节发货时间规定是什么?过年还要48小时发货吗? e元素e8100无线鼠标怎么使用 E元素X-8100靠谱吗?可以用几年? E元素X-8100现在有几种配色,哪一种配色好呢? E元素X-8100用的是什么色的轴,适合玩游戏吗? 浙c是哪个城市 浙c是哪里 榻榻米软包怎么安装 MySQL 如何追踪sql语句的执行 如何跟踪SQL SERVER 正在执行的语句 oracle 10g 中怎么跟踪SQL语句呀 产品对数据库的操作,sql语句在哪里能够... Oracle数据库跟踪 mysql 怎样进行数据库跟踪 如何使用SQL Server 跟踪数据库变化 oracle数据库,如何跟踪语句? Oracle 数据库如何跟踪SQL语句 "我的梦想是周游世界"用日语可以这么说吗? 暖暖环游世界的芙蕾雅之梦怎么获得 环游世界是一个理想吗 暖暖环游世界青叶的梦套装怎么得 如何才能完成我的梦——环游世界 环球世界需要多少钱? 暖暖环游世界的梦之阁里怎样抽到30个卡片 想要环游世界,又想找份好工作,去应聘机长是否是最合适的选择? 梦见和几个朋友飞到天上,底下就是海,能看到下面的一切,环游世界,而且还感觉以前做过相似的梦,这有什 怎么样才能实现自己环游世界的梦想呢 你觉得一个普通人要如何实现环游世界的梦想? 为什么那么多人有环游世界的梦想 mssql2012或navicat10 数据库跟踪 数据库跟踪audit loeout什么意思 sql语法的跟踪 SQL Server Profiler 2008 怎么追踪特定种类语句如 insert,update,delete,能指定某个数据追踪吗 有什么工具可以跟踪完整的sql语句 vivo手机微信小视频发不出去怎么办? SQL Server Profiler怎么跟踪指定数据库标识ID sql数据库追踪问题 如何打开oracle的sql后台跟踪功能 vivox6plus微信发不了小视频怎么办 vivox5max为什么微信发不了视频啊 vivo xplay5微信发不出去视频和图片是怎么回事 vivo手机微信发不了语音和视频还有图片。好友发的 视频和照片也看不了 vivo x5max微信发不了小视频 vivoipoopor5G为什么微信视频发送失败? vivox5sl微信发不了图片和视频什么原因 哪些网站可以下载免费的高中物理教学视频? 谁能推荐几个好点的高中物理教学视频网址 高中物理教学视频下载 有没有学习高中物理的软件,尽量免费