网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.Oracle数据库技术(14).
.Oracle临时表 使用补充.
.系统设定常用指令(2).
.把应用程序程序和ORACLE客户端一.
.ORACLE中LOB字段的使用和维护.
.oralce数据库日志查看方法探讨.
.全文索引查询模板的使用.
.RHAS 3.0上的Oracle 9i的安装.
.Oracle ERP 11业务调研报告-AP应.
.Oracle 产品技术文档—Oracle9i.
.在Oracle10gisqlplus下登录dba用.
.在Oracle中实现定时操作---Job Q.
.在Linux下安装Oracle 9i.
.Linux构建网站案例.
.经典Oracle图书推荐-之三.
.Oracle的面试问题——技术知识篇.
.Oracle与Unisys为企业客户提供新.
.Oracle8 优化技术:输入/输出.
.ORACLE中如何实现ASCII字符串和1.
.oracle中用创建表时Storage中参数.

如何收集sql跟踪信息

发表日期:2008-2-9


  在诊断数据库系统性能的过程中,总会涉及到跟踪效率低下的sql语句,现在就如何跟踪sql语句来做一个简单的总结。权做抛砖引玉之用。   假如我们可以修改应用系统的源代码,则可以直接在程序中加入如下的语句:   1)alter session set timed_statistics=true; /*适用于Oracle 7.3以后的版本*/   2)alter session set max_dump_file_size=unlimited ; /*适用于Oracle 7.3以后的版本*/   3)alter session set tracefile_identifier='POX20031031a'; /*适用于Oracle 8.1.7以后的版本*/   4)alter session set events '10046 trace name context forever, level 8';   /*在这里编写应用程序的代码*/   5)alter session set events '10046 trace name context off';   在上述语句中,语句1)是把该会话的时间统计打开,该参数默认为false.在Oracle 7.3之前的版本中,不能在会话级设置该参数,只能修改初始化文件然后重新启动数据库,这样将在实例级打开时间统计。   语句2)是把跟踪文件的大小设置成操作系统所答应的最大尺寸,这样可以防止跟踪文件在完成所需要的跟踪之前被填布满,此外需要注重的是确保存放跟踪文件的目录要有足够的空间,否则将会收到“文件系统已满”错误。   语句3)的作用是使生成的跟踪文件名称中包含'POX20031031a'字符串,这样可以使你很轻易的找到所需的跟踪文件,该参数在Oracle 8.1.7之后可用。   语句4)和语句5)的作用分别是打开和关闭跟sql跟踪,你可以在这两个语句之间写入应用程序的代码,这些代码的执行情况都将被跟踪。需要注重的是语句4)的level要害字,它用来指定跟踪级别,一共有0,1,2,4,8,12六个级别可以设置,0相当于关闭跟踪;1是输出一般的跟踪信息,不包括绑定变量和等待信息;2和1相同;4是在级别1的基础上增加绑定变量信息;8是在级别1的基础上增加等待信息;级别12是输出包含级别1,4,8的所有信息。   假如应用程序的代码无法修改或者是不想去修改,则可以在其他会话中打开对特定会话的跟踪,方法如下:   1)sys.dbms_system.set_bool_param_in_session(:sid, :serial,'timed_statistics', true);   2)sys.dbms_system.set_int_param_in_session( :sid, :serial,'max_dump_file_size', 2147483647);   打开和关闭跟踪的第一种方法(oracle推荐):   3.1)sys.dbms_support.start_trace_in_session(:sid, :serial,waits=>true, binds=>false);   /* 在此期间运行要跟踪的应用程序*/   4.1)sys.dbms_support.stop_trace_in_session(:sid, :serial);   打开和关闭跟踪的第二种方法:   3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 8, '');   /*在此期间运行要跟踪的应用程序*/   3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 0, '');   以上语句中的:sid和:serial分别代表所要跟踪的会话的ID和序列号,这些信息可以从V$SESSION视图的SID和SERIAL#列获得。打开关闭跟踪中第一种方法的好处是你不用自己写10046这个事件号,这样可以减少错误,但是dbms_support程序包在你的数据库中可能会不存在,这样就只有用第二种方法了。   到现在为止,我们已经生成了所需要的跟踪文件,然后我们需要找到该文件来进行分析。跟踪文件的存放位置只有两种可能,Oracle参数USER_DUMP_DEST 或者BACKGROUND_DUMP_DEST指定的目录;文件名称根据不同的平台会有所不同,但是在文件名中都会包含会话所对应的操作系统进程(线程)号,也就是V$PROCESS的SPID列(V$PROCESS.SPID) ,该信息可以通过 v$process.addr和v$session.paddr做表连接查询得到。例如:select spid from v$process p,v$session s where p.addr=s.paddr and s.sid=:sid and s.serial#=:serial.   本文只对Oracle在使用专用服务器进程(Dedicated Server)模式做了总结,至于的共享服务器(Shared Server)模式和在应用级使用连接池的情况下,收集sql跟踪信息的方法会比较复杂,希望有相关经验的高手来总结。
上一篇:查找bad sql的方法 人气:572
下一篇:Oracle-SQL长度限制 人气:1042
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐