oracle如何跟踪 oracle语句跟踪

oracle 怎么跟踪有问题session 的sqlselect sid,v$session.serial#,v$process.spid,v$session.username,last_call_et,status,LOCKWAIT,machine,logon_time,sql_text from v$session, v$process, v$sqlarea where paddr = addr and sql_hash_value = https://www.04ip.com/post/hash_value and v$session.username is not null and sql_text not like'%session%' andstatus='ACTIVE' order by last_call_et desc;
查询当前正在执行的sql及执行用时,如果对性能优化查看sql效率要set autotrace on;然后执行sql查看执行计划 。
oracle怎么跟踪过程的执行需要建立一张表来记录
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
【oracle如何跟踪 oracle语句跟踪】Id;
ID 'name'是一个标识,你可以自己取 , 字段有很多个 , 以下是各个字段的解释(可能格式不对 , 你可以复制后看):
字段名字段类型含义
STATEMENT_IDVARCHAR2(30)explain PLAN 语句中所指定的最优STATEMENT_ID 参数值, 如果在EXPLAN PLAN语句中没有使用SET STATEMENT_ID,那么此值会被设为NULL 。
REMARKSVARCHAR2(80)与被解释规划的各步骤相关联的注释最长可达80 字节
OPERATIONVARCHAR2(30)各步骤所执行内部操作的名称在某条语句所产生的第一行中该列的可能取值如下DELETE STATEMENT INSERT STATEMENT SELECT STATEMENT UPDATE STATEMENT
OPTIONSVARCHAR2(30)对OPERATION 列中所描述操作的变种
OBJECT_NODEVARCHAR2(128)用于访问对象的数据库链接database link 的名称对于使用并行执行的本地查询该列能够描述操作中输出的次序
OBJECT_OWNERVARCHAR2(30)对于包含有表或索引的架构schema 给出其所有者的名称
OBJECT_NAMEVARCHAR2(30)表或索引的名称
OBJECT_INSTANCEINTEGER根据对象出现在原始original 语句中的次序所给出的相应次序编号就原始的语句文本而论其处理顺序为自左至右自外向内景象扩张view
OBJECT_TYPEVARCHAR2(30)用于提供对象描述性信息的修饰符例如索引的NON-UNIQUE
OPTIMIZERVARCHAR2(255)当前优化程序的模式
IDINTEGER分配给执行规划各步骤的编号
PARENT_IDINTEGER对ID 步骤的输出进行操作的下一个执行步骤的ID
POSITIONINTEGER对于具有相同PARENT_ID 的步骤其相应的处理次序
COSTINTEGER根据优化程序的基于开销的方法所估计出的操作开销值对于使用基于规则方法的语句该列为空该列值没有特定的测量单位它只是一个用于比较执行规划开销大小的权重值
CARDINALITYINTEGER根据基于开销的方法对操作所访问行数的估计值
BYTESINTEGER根据基于开销的方法对操作所访问字节的估计
=============================================
你按照我说的做,后面用
SELECT
*
FROM
PLAN_TABLE A
WHERE
STATEMENT_ID='name'
结果已经很清楚了,全部满足你的要求 。
各列的具体含义上面已经给出 。
如何查找ORACLE中的跟踪文件查看归档模式
conn /as sysdba
archive log list
如果数据库为归档模式的话,可以通过logmnr来进行挖掘日志文件查看这些信息的 。如果是非归档模式 。对不起无法查看了
开启后台进程跟踪,
设置参数(initsid.ora)
.backgroudn_dump_dest=目录名--指定根踪文件存放的路径
.user_dmup_test=目录名--指定用户信息跟踪文件的存放路径
.用户的跟踪文件(.trc),用TKPROF来格式化用户跟踪文件
SQL语句跟踪即可 。
.imed_statistics=true;--设置启用sql_trace=true;
.user_dump_dest=目录--指定跟踪文件的存放路径
.max_dump_file_size=5M--指定跟踪文件最大尺寸
.SQL_TRACE=TRUE;
.动态改变:altersessionsetsql_trace=true;
或者打开生成的跟踪文件:
默认在..\oralce\admin\user\udump\*.trc,由于oralce生成的*.trc直接打开格式不规格,看得很累 , 可以用tkprofgk来格式化:c:\tkprofora00001.trca.txt
如何在Oracle数据库10g中跟踪SQL1. 启用 sql_trace 跟踪当前 session
开启会话跟踪:alter session set sql_trace=true;
关闭会话跟踪:alter session set sql_trace=false;
2. 启用 10046 事件跟踪全局 session
这将会对整个系统的性能产生严重的影响,所以一般不建议开启 。
开启会话跟踪:alter system set events ‘10046 trace name context forever, level 12’;
关闭会话跟踪:alter system set events ‘10046 trace name context off’;
3. 使用 Oracle 系统包 DBMS_SYSTEM.SET_EV 跟踪指定 session
开启会话跟踪:SQL exec dbms_system.set_ev(143, 112, 10046, 12, '');
关闭会话跟踪:SQL exec dbms_system.set_ev(143, 112, 10046, 0, '');
如何跟踪oracle用户,并得到跟踪信息用hibernate没有oracle如何跟踪,用oracle如何跟踪的设置属性show_sql为true
没用,只想从后台数据库看对这个数据库执行oracle如何跟踪的sql问题补充:unika_ly12 写道
那你直接查询 v$sqltext 和 v$session 好oracle如何跟踪了
首先,你要以dba身份登陆数据库 。
第二 , 为某个用户开启sql跟踪 。那个用户就是你要跟踪的、正在执行sql语句的那个用户 。命令如下:
execute dbms_system.set_sql_trace_in_session(sid,serial#,true)
其中参数的意义是,sid-会话id,serial#-序列号,这两个参数可以从v$session中得到 。
第三,上面的命令执行成功之后数据库就自动对该用户所发出的所有sql语句进行跟踪,并把结果写在用户跟踪文件里 。用户跟踪文件存放在数据库服务器上 , 路径请参考init.ora文件中的udump参数值 。文件名为ora_sid_xxxx.trc(for unix)或者oraxxxxx.trc(for NT),其中xxxx文件系统进程编号 , 这个编号可以从v$process和v$session两个表通过关联的方式查询得到 。当然你也可以简单的查看一下哪个trc文件的日期最新,哪个文件就是你要的结果了 。
首先,你要以dba身份登陆数据库 。
第二 , 为某个用户开启sql跟踪 。那个用户就是你要跟踪的、正在执行sql语句的那个用户 。命令如下:
execute dbms_system.set_sql_trace_in_session(sid,serial#,true)
其中参数的意义是,sid-会话id,serial#-序列号 , 这两个参数可以从v$session中得到 。
第三,上面的命令执行成功之后数据库就自动对该用户所发出的所有sql语句进行跟踪 , 并把结果写在用户跟踪文件里 。用户跟踪文件存放在数据库服务器上,路径请参考init.ora文件中的udump参数值 。文件名为ora_sid_xxxx.trc(for unix)或者oraxxxxx.trc(for NT),其中xxxx文件系统进程编号 , 这个编号可以从v$process和v$session两个表通过关联的方式查询得到 。当然你也可以简单的查看一下哪个trc文件的日期最新,哪个文件就是你要的结果了 。
execute dbms_system.set_sql_trace_in_session(sid,serial#,false)Good Luckoracle如何跟踪我按你说的做了一遍,execute dbms_system.set_sql_trace_in_session(sid,serial#,true)
oracle如何跟踪的介绍就聊到这里吧,感谢你花时间阅读本站内容 , 更多关于oracle语句跟踪、oracle如何跟踪的信息别忘了在本站进行查找喔 。

    推荐阅读