oracle的解析器,Oracle中sql量化分析工具

Oracle提供的量化分析工具有explain,sql*trace,tkprof,auto*trace,awr,addm,sql*profiling,sql access advisor,sql tuning advisor,ash等

此次主要整理了explain,sql*trace,tkprof,auto*trace的使用

1.explain

2.sql*trace

3.tkprof

4.auto*trace

1.explain的使用

1.1 先创建plan_table

@?/rdbms/admin/utlxplan ;

1.2 分析sql语句执行计划

explain plan for select * from dba_objects ;

1.3 查看sql语句执行计划

@?/rdbms/admin/utlxpls.sql; 9i下只查看串行执行计划,10g既查看串行也查看并行

@?/rdbms/admin/utlxplp.sql; 查看并行执行计划

explain并没有真正的执行sql语句,所以实际过程可能与explain分析结果不相同。如explain分析之后,又对相关表建立了新的索引或者删除了索引、采集了新的统计信息等操作

10g中的新功能 dbms_xplan

dbms_xplan.display

显示存储在v$sql_plan视图中的语句执行计划

dbms_xplan.display_cursor

显示任何加载的cursor中的语句执行计划

dbms_xplan.display_awr

显示保存在awr中的语句执行计划

select plan_table_output from table(dbms_xplan.display()) ;

2.sql*trace和tkprof的使用

大致的过程如下所示

database--(sql trace)--trace file--(tkprof)--report file

sql*trace和explain不同的是,sql*trace不是针对单个sql语句进行执行计划分析的,而是在会话级,甚至实例级对sql语句进行跟踪,并在操作系统中产生相应的trace文件

sql*trace是跟踪sql语句的真实执行执行情况,Oracle提供tkprof程序将trace文件转换为可读性较强的文件

2.1 在会话级进行跟踪alter session set sql_trace = true ;

execute dbms_session.set_sql_trace(true) ;

其他会话的跟踪execute dbms_system.set_trace_in_session(session_id,serial_id,true);

分析的时候,首先查看那些会话比较消耗资源,然后从v$session视图查询session_id,serial_id,通过以上的命令对这些会话的活动进行跟踪和分析

2.2 在实例级进行跟踪

设置sql_trace为true即可

建议不要采取这个措施,会对数据库产生较大的压力,会产生太多的trace文件

使用sql_trace产生的trace文件,原始文件阅读起来相对比较费劲,可以使用tkprof程序进行转换

例如:

tkprof tracefile outputfile [options]

tkprof tracefile outputfile sys=no explain=hr/hr sort=execcput print=3

sys=no表示不分析sys用户执行的sql语句

explain=hr/hr 表示连接到hr用户,并进行执行计划分析

sort=execcput 表示按照CPU消耗值,对该trace文件所包含的sql语句按照排序进行分析

print=3 表示只是分析前3条sql语句

直接在os输入tkprof可以查看所有的帮助

tkprof产生的文件,主要分析以下内容

1.各语句执行情况的统计信息

2.各语句的执行路径信息

3.autotrace的使用

3.1 打开autotrace

set autotrace on

set timing on

执行sql语句

3.2 只看执行计划、统计信息

set autotrace traceonly

3.3 只看执行计划

set autotrace traceonly explain

autotrace是语句真正执行之后的执行计划

3.4 只看统计信息

set autotrace statistics

3.5 查看帮助

set autotrace

Usage: SET AUTOT[RACE] {OFF | ON | TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]]

3.6 如何查看统计信息

重点查看consistent gets和physical reads指标,分别代表内存消耗和磁盘IO消耗,单位是数据块大小(db_block_size)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值