SQL Trace是Oracle提供的用于举行SQL追寻的手段,是强有力的帮助诊断工具。在平时的数据库问题诊断和处理中,SQL TRACE是极其常用的措施。
SQL TRACE的顺次追寻能够分为以下几步:
1、界定必需追寻的目标范围,并利用贴切的号召启用所需追寻。
2、穿越一段工夫后,静止追寻。此刻该当发生了一个追寻收获文件。
3、找到追寻文件,并对其举行款式化,然后阅读或分析。
本文就SQL TRACE的这些利用作容易摸索,并穿越翔实案例对SQL_TRACE的利用举行解释。
SQL TRACE的启用
SQL_TRACE解释:SQL_TRACE能够作为初始化参数在大局启用,也能够穿越号召行措施在翔实session启用。
1.在大局启用
在参数文件(pfile/spfile)中指定: SQL_TRACE = true。
在大局启用SQL_TRACE会导致所有历程的行动被追寻,包括后台历程及所有用户历程,这等闲会导致比拟严重的功能问题,因而在出产环境中要持重利用。
提醒: 穿越在大局启用SQL_TRACE,我们能够追寻到所有后台历程的行动,许多在文档中的笼统解释,穿越追寻文件的实时改变,我们能够打听的看到各个历程之间的紧凑调停。
2.在目前session级设置
大多数时候我们利用SQL_TRACE追寻目前会话的历程。穿越追寻目前历程能够觉察目前垄断的后台数据库递归行动(这在琢磨数据库新个性时尤其管用),琢磨SQL厉行,觉察后台讹谬等。
在session级启用和静止SQL_TRACE措施如下:
启用目前session的追寻:
SQL>altersessionsetSQL_TRACE=true; Sessionalteredbr.brandmats.cn.
此刻的SQL垄断将被追寻:
SQL>selectcount(*)fromdba_users; COUNT(*) ---------- 34
告终追寻:
SQL>altersessionsetSQL_TRACE=false; Sessionaltered.
3.追寻其它用户历程
在许多时候我们必需追寻其他用户sc.scjszp.com的历程,而不是目前用户,这能够穿越Oracle供给的系统包DBMS_SYSTEM.SET_SQL_TRACE_IN_SESSION来告终。
SET_SQL_TRACE_IN_SESSION过程序要供给三个参数:
SQL>descDBMS_SYSTEM.SET_SQL_TRACE_IN_SESSION; ParameterTypeModeDefault? ---------------------------- SIDNUMBERIN SERIAL#NUMBERIN SQL_TRACEBOOLEANIN
穿越v$session我们能够获得sid、serial#等消息:
获得历程消息,抉择必需追寻的历程:
SQL>selectsid,serial#,usernamefromv$session 2whereusernameisnotnull; SIDSERIAL#USERNAME -------------------------------------------------- 82041SYS 9437EYGLE
设置跟着:
SQL>execdbms_system.set_SQL_TRACE_in_session(9,437,true) PL/SQLproceduresuccessfullycompleted. ….
能够期待刹那,追寻session厉行任务,捉拿sql垄断…
静止追寻:
SQL>execdbms_system.set_SQL_TRACE_in_session(9,437,false) PL/SQLproceduresuccessfullycompleted.
10046事件解释
10046事件是Oracle供给的内部事件,是对SQL_TRACE的加深。
10046事件能够设置以下四个级别:
1 – 启用规范的SQL_TRACE功能,等价于SQL_TRACE。4 – Level 1 加上绑定值(bind values)8 – Level 1 + 期待事件追寻12 – Level 1 + Level 4 + Level 8相仿SQL_TRACE措施,10046事件能够在大局设置,也能够在session级设置。
关于Oracle数据库追踪工具SQL Trace的知识就介绍到这里了,希望本次的介绍能够带给您一些收获!
【编辑推荐】
- Oracle数据库常见问题及解决方案大全怎样用Oracle的ODP.NET创建实体数据模型数据库优化技术之Oracle数据库动态绑定变量PL/SQL Developer导入导出数据库方法及说明Oracle 11g即时客户端在Windows系统上的配置