根据sid查找历史sql执行计划

1. 前提知道相关的信息 比如sid,serial# 或者sql_id. 我这里只是知道开发给的一个sid,就以此为例子。

相关视图 V$active_session_history ,dba_hist_active_sess_history

由于我这个session已经跑完,而且过了一天才汇报过来,只能选择 dba_hist_active_sess_history这个视图。这里我得到的是sid号为 2398.

select sample_time,user_id,sql_id,session_serial# from dba_hist_active_sess_history where session_id='2398' order by sample_time;

可以根据sample_time来,来找到当时的时间点,进而找到对应的 sql_id.

24-SEP-13 02.16.56.201 AM                                                           80 g1a6hqyarsy0a            7598
24-SEP-13 02.17.06.201 AM                                                           80 g1a6hqyarsy0a            7598
24-SEP-13 02.17.16.211 AM                                                           80 g1a6hqyarsy0a            7598
24-SEP-13 02.17.26.221 AM                                                           80 g1a6hqyarsy0a            7598
24-SEP-13 02.17.36.221 AM                                                           80 g1a6hqyarsy0a            7598

2.根据sql_id来做进一步的查找

select * from table(dbms_xplan.display_cursor('g1a6hqyarsy0a'));或者select sql_text from v$sqltext where sql_id='g1a6hqyarsy0a' order by piece;

这样可以得到原sql语句与其对应执行计划。


3.如果这个语句比以往跑慢了。需要去分析执行计划,比对区别。

相关视图dba_hist_sql_plan

SQL> select distinct dbid,sql_id,PLAN_HASH_VALUE,timestamp from dba_hist_sql_plan where sql_id='g1a6hqyarsy0a' order by timestamp;

 

     DBID SQL_ID        PLAN_HASH_VALUE TIMESTAMP
---------- ------------- --------------- ---------
3393184898 g1a6hqyarsy0a      3291279211 04-JAN-11
3393184898 g1a6hqyarsy0a      1944625860 24-SEP-13

这个可以根据不同的hash值来进行每次的执行计划分析。

select * from table(dbms_xplan.DISPLAY_AWR('SQL_ID','HASH','DBID','format'));


format可以参考链接:http://blog.csdn.net/leshami/article/details/6866870




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东方-phantom

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值