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
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 的名称对于使用并行执行的本地查询该列能够描述操作中输出的次序
【oracle跟踪如何用 oracle 跟踪】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怎样开启sql跟踪一.在系统级别上设置sql跟踪
该方法优点:可以跟踪所有的oracle的后台进程所执行的sql,包括系统后台进程和用户进程,并且可以跟踪所有的操作
缺点:跟踪所有的后台进程,跟踪信息量比较大
1.在sqlplus中以sys/ as sysdba身份登陆到数据库 。
2.打开跟踪,在sqlplus中输入alter sysetem set events '10046 trace name context forever,level level';
(其中level可以输入1,4,8,12三个级别,不同的级别含有不同级别的信息)
3.然后到ArcMap或ArcCatalog中进行你想跟踪的操作
4.关闭跟踪,在sqlplus中输入alter systemm set events '10046 trace name context off';
5.查找你所跟踪的session的ID
A 修改时间格式:alter session set nls_date_format='YYYY-MM-DD HH24:MI:SS';
B.对使用sde服务的输入:select sid,logon_time from v$session where username=username and program='gsrvr.exe';
C.对直连这种方式输入:select sid,logon_time from v$session where username=username and program='ArcCatalog';
select sid,logon_time from v$session where username=username and program='ArcMap';
(其中username是程序登陆到数据库的用户名,如果返回多个结果,在根据登陆的时间确定具体的sid值)
6.执行以下的sql语句
SELECT d.VALUE
|| '/'
|| LOWER (RTRIM (i.INSTANCE, CHR (0)))
|| '_ora_'
|| p.spid
|| '.trc' trace_file_name
FROM (SELECT p.spid
FROM v$mystat m, v$session s, v$process p
WHERE m.statistic# = 1 AND s.SID = SID AND p.addr = s.paddr) p,
(SELECT t.INSTANCE
FROM v$thread t, v$parameter v
WHERE v.NAME = 'thread'
AND (v.VALUE = https://www.04ip.com/post/0 OR t.thread# = TO_NUMBER (v.VALUE))) i,
(SELECT VALUE
FROM v$parameter
WHERE NAME = 'user_dump_dest') d
在输入sid后,即得到后台的跟踪文件 。
二. 在session级别上设置跟踪
该方法只适用于跟踪登陆数据后所进行的一系列的操作,比如跟踪在ArcCatalog中创建一个Dataset,FeatureClass等的操作
1.在sqlplus中以sys / as sysdba身份登陆到数据库
2.查找你所要跟踪的session的sid和serial#
A 修改时间格式:alter session set nls_date_format='YYYY-MM-DD HH24:MI:SS';
B.对使用sde服务的输入:select sid,serial#,logon_time from v$session where username=username and program='gsrvr.exe';
C.对直连这种方式输入:select sid,serial#,logon_time from v$session where username=username and program='ArcCatalog';
select sid,serial#,logon_time from v$session where username=username and program='ArcMap';
(其中username是程序登陆到数据库的用户名,如果返回多个结果,在根据登陆的时间确定具体的sid和serial#的值)
3.开始跟踪,输入exec dbms_support.start_trace_in_session(sid,serial#,true,true).(如果系统没有安装dbms_support包,可以执行$ORACLE_HOME\rdbms\admin\dbmssupp.sql进行安装)
4.然后到ArcMap或ArcCatalog中进行你想跟踪的操作
5.结束跟踪exec dbms_support.stop_trace_in_session(sid,serial#);
6.执行以下的sql语句
SELECT d.VALUE
|| '/'
|| LOWER (RTRIM (i.INSTANCE, CHR (0)))
|| '_ora_'
|| p.spid
|| '.trc' trace_file_name
FROM (SELECT p.spid
FROM v$mystat m, v$session s, v$process p
WHERE m.statistic# = 1 AND s.SID = SID AND p.addr = s.paddr) p,
(SELECT t.INSTANCE
FROM v$thread t, v$parameter v
WHERE v.NAME = 'thread'
AND (v.VALUE = https://www.04ip.com/post/0 OR t.thread# = TO_NUMBER (v.VALUE))) i,
(SELECT VALUE
FROM v$parameter
WHERE NAME = 'user_dump_dest') d
在输入sid后,即得到后台的跟踪文件 。
三. 在Aix系统下跟踪消耗内存的session的办法
1.在Aix系统上执行export TERM=vt100
2.执行topas命令 , 确定最占cpu资源的process的进程号
3,然后利用select a.sid,b.serial# from v$session a,v$process b where a.paddr=b.addr and b.spid=spid;
4.确定sid和serial#后利用二方法进行跟踪 。
如何跟踪oracle用户,并得到跟踪信息用hibernate没有oracle跟踪如何用 , 用oracle跟踪如何用的设置属性show_sql为true
没用,只想从后台数据库看对这个数据库执行oracle跟踪如何用的sql问题补充oracle跟踪如何用:unika_ly12 写道
那oracle跟踪如何用你直接查询 v$sqltext 和 v$session 好了
首先,你要以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 Luck我按你说的做了一遍,execute dbms_system.set_sql_trace_in_session(sid,serial#,true)
应用软件对oracle操作的语句跟踪方法请教1.如果oracle跟踪如何用你oracle跟踪如何用的软件有源代码,可以使用跟踪调试模式来判断执行到了哪一行 。
2.如果你oracle跟踪如何用的软件是打好包oracle跟踪如何用的 只能使用ORACLE的 SQLTRACE模式..具体请搜索..ORACLE会把每个动作写到日志里,包括数据字典的操作..非常非常的详细,记得使用完毕关掉,不然你的日志会爆掉 。
如何查找ORACLE中的跟踪文件用toad oracle跟踪如何用的工具可以进行跟踪 。查找toadoracle跟踪如何用的路径 右键属性 查找相应文件夹 然后 找寻同级目录下oracle跟踪如何用的 sql_monitor 这个工具就可以对 Oracle运行数据进行跟踪 。
关于oracle跟踪如何用和oracle 跟踪的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。
推荐阅读
- 无人清仓直播卖货,无人清仓直播卖货是真的吗
- 安卓酷狗谷歌版本更新时间,酷狗音乐谷歌版本
- 养成类赛车游戏,练赛车游戏
- oracle查询默认排序,oracle查询语句排序
- mysql怎么计算总和 mysql总数
- linux命令行生成图片,LINUX命令行运行程序
- 网络游戏开发实验室名字,游戏实验室是什么
- 服务直播文案范文,服务直播话术
- vb.net+教程+下载 vbnet implements