sql trace 的几种方法
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 的几种方法相关推荐
- SQL去重的三种方法汇总
SQL去重的三种方法汇总 这里的去重是指:查询的时候, 不显示重复,并不是删除表中的重复项 1.distinct去重 注意的点:distinct 只能一列去重,当distinct后跟大于1个参数时,他 ...
- pdo_fetch执行mysql_PDO中执行SQL语句的三种方法
在PDO中,我们可以使用三种方式来执行SQL语句,分别是 exec()方法,query方法,以及预处理语句prepare()和execute()方法~大理石构件来图加工 在上一篇文章<使用PDO ...
- 《转》sql优化的几种方法
原文 在sql查询中为了提高查询效率,我们常常会采取一些措施对查询语句进行sql优化,下面总结的一些方法,有需要的可以参考参考. 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 ...
- SQL行列转换6种方法
在进行报表开发时,很多时候会遇到行列转换操作,很对开发人员针对于SQL级别行列转换操作一直不甚理解,今天正好抽空对其进行了一些简单的总结.这里主要列举3种可以实现SQL行列转换的方法,包括通用SQL解 ...
- 网站mysql防止sql注入攻击 3种方法总结
mysql数据库一直以来都遭受到sql注入攻击的影响,很多网站,包括目前的PC端以及手机端都在使用php+mysql数据库这种架构,大多数网站受到的攻击都是与sql注入攻击有关,那么mysql数据库如 ...
- SQL去重的三种方法汇总
今天来看3种SQL里去重的方法 正文 来自:blog.csdn.net/xienan_ds_zj/article/details/103869048 转自:程序员的成长之路 在使用SQL提数的时候,常 ...
- SQL分页的三种方法
三种SQL分页法 表中主键必须为标识列,[ID] int IDENTITY (1,1) 1.分页方案一:(利用Not In和SELECT TOP分页) 语句形式: SELECT TOP 10 * FR ...
- C#将Excel数据表导入SQL数据库的两种方法(转)
最近用写个winform程序想用excel 文件导入数据库中,网上寻求办法,找到了这个经过尝试可以使用. 方法一: 实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环 ...
- jsp工程防止外部注入_防止 jsp被sql注入的五种方法
一.SQL注入简介 SQL注入是比较常见的网络攻击方式之一,它不是利用操作系统的BUG来实现攻击,而是针对程序员编程时的疏忽,通过SQL语句,实现无帐号登录,甚至篡改数据库. 二.SQL注入攻击的总体 ...
最新文章
- OCM_第十二天课程:Section6 —》数据库性能调优_ 资源管理器/执行计划
- Vivado中用于时钟操作的几个Tcl命令
- .net 考试系统人一多就断开了_2020年银行从业资格考试成绩查询入口已开放
- 在一个TextArea中如何限制行数和字符数
- 【CMD】 与路径相关的常量:当前目录的绝对路径、批处理文件所在目录的绝对路径、批处理文件的全路径
- Linux安装软件包
- 面试:TCP协议面试10连问,总会用得到,值得收藏!
- 写在前面-2015.11.30
- easyExcel实现Excel导出功能
- Facebook 开源 Instagram 的Python 代码静态安全分析工具 Pysa
- 面向对象组合及三大特性
- 数值计算——追赶法求解三对角方程组(附代码)
- mini-pcie接口(EC20和N720)
- 黑客游戏(强烈推荐)攻防ctf
- Resolution-robust Large Mask Inpainting with Fourier Convolutions 解读
- 实现两个路由器漫游(传统路由器做AP)
- Win7不显示移动硬盘盘符的解决方法
- 汉语拼音的5个声调该怎么学?
- python 股票盯盘v2.0
- 华硕笔记本节能证书_有这本证书的人恭喜啦,国家正式要求,企业必备
热门文章
- 2021年高考成绩查询达州,四川省达州市2021年普通高校招生网上报名入口
- python求导并作图_科学网—python-符号运算(求导等) - 夏江江的博文
- 君子不玩物丧志,亦常以借物调心,网站集成二次元网页小组件(widget)石蒜模拟器,聊以赏玩
- 【javaweb简单教程】1.搭建Web环境、初识JSP
- 关于安装myeclipse7.5或者myeclipse7.0出现问题
- Android实现二维码扫描功能(四)-ZXing识别图片二维码,相册选图
- 分布式数据库系统之【结构】
- 【ArcGIS Pro二次开发】(7):地图(Map)的基本操作
- 基于SDK的支付接口服务端——支付宝,微信
- [置顶] 中国象棋程序的设计与实现(高级版)(项目截图)