1.sql_trace
a. 全局
在 pfile/spfile 中使用
sql_trace=true
导致所有进程的活动都被跟踪,后台进程和用户SESSION ,导致严重的性能问题。慎重使用

b.当前SESSION
alter session set sql_trace=true ;
alter session set sql_trace=flase ;

c.跟踪指定的SESSION

DBMS_SYSTEM. SET_SQL_TRACE_IN_SESSION(SID,SERIAL#,SQL_TRACE);
EXP:

select sid,serial#,username from v$session ;
exec dbms_system.set_sql_trace_in session(sid,s#,true);

2.autotrace

autotrace 只能用于sqlplus

set autotrace [on|state|traceonly]
set timming on

3.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级设置。

全局
pfile文件中加
event ="10046 trace name context forever,level 12"
包括所有进程后台进程
当前session
SQL> alter session set events '10046 trace name context forever';

Session altered.

SQL> alter session set events '10046 trace name context forever, level 8';

Session altered.

SQL> alter session set events '10046 trace name context off';

Session altered.

对其他用户session设置
通过DBMS_SYSTEM.SET_EV系统包来实现:

SQL> desc dbms_system
...
PROCEDURE SET_EV
 Argument Name                  Type                    In/Out Default?
 ------------------------------ ----------------------- ------ --------
 SI                             BINARY_INTEGER          IN
 SE                             BINARY_INTEGER          IN
 EV                             BINARY_INTEGER          IN
 LE                             BINARY_INTEGER          IN
 NM                             VARCHAR2                IN

...

其中的参数SI、SE来自v$session视图:

查询获得需要跟踪的session信息:SQL> select sid,serial#,username from v$session where username is not null;
SID SERIAL# USERNAME
---------- ---------- ------------------------------
8 2041 SYS
9 437 test

执行跟踪:
SQL> exec dbms_system.set_ev(9,437,10046,8,'test');

PL/SQL procedure successfully completed.

结束跟踪:
SQL> exec dbms_system.set_ev(9,437,10046,0,'test');

PL/SQL procedure successfully completed.

(c) 获取跟踪文件
以上生成的跟踪文件位于user_dump_dest目录中,位置及文件名可以通过以下SQL查询获得:

SQL> select  2    d.value||'/'||lower(rtrim(i.instance, chr(0)))||'_ora_'||p.spid||'.trc' trace_file_name  3  from  4    ( select p.spid  5      from sys.v$mystat m,sys.v$session s,sys.v$process p  6      where m.statistic# = 1 and s.sid = m.sid and p.addr = s.paddr) p,  7    ( select t.instance from sys.v$thread  t,sys.v$parameter  v  8      where v.name = 'thread' and (v.value = 0 or t.thread# = to_number(v.value))) i,  9    ( select value from sys.v$parameter where name = 'user_dump_dest') d 10  /

TRACE_FILE_NAME
--------------------------------------------------------------------------------
/opt/oracle/admin/hsjf/udump/test_ora_1026.trc

(d) 读取当前session设置的参数
当我们通过alter session的方式设置了sql_trace,这个设置是不能通过show parameter的方式得到的,我们需要通过dbms_system.read_ev来获取:

SQL> set feedback offSQL> set serveroutput on
SQL> declare
2 event_level number;
3 begin
4 for event_number in 10000..10999 loop
5 sys.dbms_system.read_ev(event_number, event_level);
6 if (event_level > 0) then
7 sys.dbms_output.put_line(
8 'Event ' ||
9 to_char(event_number) ||
10 ' is set at level ' ||
11 to_char(event_level)
12 );
13 end if;
14 end loop;
15 end;
16 /
Event 10046 is set at level 8

sql trace 的几种方法相关推荐

  1. SQL去重的三种方法汇总

    SQL去重的三种方法汇总 这里的去重是指:查询的时候, 不显示重复,并不是删除表中的重复项 1.distinct去重 注意的点:distinct 只能一列去重,当distinct后跟大于1个参数时,他 ...

  2. pdo_fetch执行mysql_PDO中执行SQL语句的三种方法

    在PDO中,我们可以使用三种方式来执行SQL语句,分别是 exec()方法,query方法,以及预处理语句prepare()和execute()方法~大理石构件来图加工 在上一篇文章<使用PDO ...

  3. 《转》sql优化的几种方法

    原文 在sql查询中为了提高查询效率,我们常常会采取一些措施对查询语句进行sql优化,下面总结的一些方法,有需要的可以参考参考. 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 ...

  4. SQL行列转换6种方法

    在进行报表开发时,很多时候会遇到行列转换操作,很对开发人员针对于SQL级别行列转换操作一直不甚理解,今天正好抽空对其进行了一些简单的总结.这里主要列举3种可以实现SQL行列转换的方法,包括通用SQL解 ...

  5. 网站mysql防止sql注入攻击 3种方法总结

    mysql数据库一直以来都遭受到sql注入攻击的影响,很多网站,包括目前的PC端以及手机端都在使用php+mysql数据库这种架构,大多数网站受到的攻击都是与sql注入攻击有关,那么mysql数据库如 ...

  6. SQL去重的三种方法汇总 ​

    今天来看3种SQL里去重的方法 正文 来自:blog.csdn.net/xienan_ds_zj/article/details/103869048 转自:程序员的成长之路 在使用SQL提数的时候,常 ...

  7. SQL分页的三种方法

    三种SQL分页法 表中主键必须为标识列,[ID] int IDENTITY (1,1) 1.分页方案一:(利用Not In和SELECT TOP分页) 语句形式: SELECT TOP 10 * FR ...

  8. C#将Excel数据表导入SQL数据库的两种方法(转)

    最近用写个winform程序想用excel 文件导入数据库中,网上寻求办法,找到了这个经过尝试可以使用. 方法一: 实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环 ...

  9. jsp工程防止外部注入_防止 jsp被sql注入的五种方法

    一.SQL注入简介 SQL注入是比较常见的网络攻击方式之一,它不是利用操作系统的BUG来实现攻击,而是针对程序员编程时的疏忽,通过SQL语句,实现无帐号登录,甚至篡改数据库. 二.SQL注入攻击的总体 ...

最新文章

  1. OCM_第十二天课程:Section6 —》数据库性能调优_ 资源管理器/执行计划
  2. Vivado中用于时钟操作的几个Tcl命令
  3. .net 考试系统人一多就断开了_2020年银行从业资格考试成绩查询入口已开放
  4. 在一个TextArea中如何限制行数和字符数
  5. 【CMD】 与路径相关的常量:当前目录的绝对路径、批处理文件所在目录的绝对路径、批处理文件的全路径
  6. Linux安装软件包
  7. 面试:TCP协议面试10连问,总会用得到,值得收藏!
  8. 写在前面-2015.11.30
  9. easyExcel实现Excel导出功能
  10. Facebook 开源 Instagram 的Python 代码静态安全分析工具 Pysa
  11. 面向对象组合及三大特性
  12. 数值计算——追赶法求解三对角方程组(附代码)
  13. mini-pcie接口(EC20和N720)
  14. 黑客游戏(强烈推荐)攻防ctf
  15. Resolution-robust Large Mask Inpainting with Fourier Convolutions 解读
  16. 实现两个路由器漫游(传统路由器做AP)
  17. Win7不显示移动硬盘盘符的解决方法
  18. 汉语拼音的5个声调该怎么学?
  19. python 股票盯盘v2.0
  20. 华硕笔记本节能证书_有这本证书的人恭喜啦,国家正式要求,企业必备

热门文章

  1. 2021年高考成绩查询达州,四川省达州市2021年普通高校招生网上报名入口
  2. python求导并作图_科学网—python-符号运算(求导等) - 夏江江的博文
  3. 君子不玩物丧志,亦常以借物调心,网站集成二次元网页小组件(widget)石蒜模拟器,聊以赏玩
  4. 【javaweb简单教程】1.搭建Web环境、初识JSP
  5. 关于安装myeclipse7.5或者myeclipse7.0出现问题
  6. Android实现二维码扫描功能(四)-ZXing识别图片二维码,相册选图
  7. 分布式数据库系统之【结构】
  8. 【ArcGIS Pro二次开发】(7):地图(Map)的基本操作
  9. 基于SDK的支付接口服务端——支付宝,微信
  10. [置顶] 中国象棋程序的设计与实现(高级版)(项目截图)