飞道的博客

last_load_time和last_active_time的选择

314人阅读  评论(0)

我们平台在查找使用全表扫描执行计划的SQL时,发现有些应用跑过逻辑的SQL,确认用的全表扫,但是未能实时的检索到,于是,看下用的SQL,


   
  1. SELECT s.sql_text, P.OBJECT_OWNER,
  2.        P.SQL_ID,
  3. P.OPERATION,
  4. P.OPTIONS,
  5.        S.LAST_LOAD_TIME,
  6. ROW_NUMBER() OVER( PARTITION BY P.SQL_ID ORDER BY P.SQL_ID) AS ROWNUMS
  7. FROM V$SQL_PLAN P, V$SQLAREA S
  8. WHERE S.SQL_ID = P.SQL_ID
  9.     AND P.OPERATION =  'TABLE ACCESS'
  10.     AND P.OPTIONS =  'FULL'
  11.     AND S.LAST_LOAD_TIME >= trunc( SYSDATE -1)
  12. ORDER BY S.SQL_TEXT, P.SQL_ID

逻辑其实很简单,就是将v$sql_plan和v$sqlarea视图进行关联,根据operation和options找到TABLE ACCESS FULL关键字,并加上时间条件,但是为什么应用确认肯定跑过的逻辑,而且肯定是全表扫描的SQL,不能找到?

究其原因,就和这个时间条件相关。我们看到,SQL中过滤时间的字段是v$sqlarea中的last_load_time,指定了大于等于昨天的00:00:00,除了这个字段,其实有个last_active_time字段,和这个很像,两者有什么区别?

在v$sqlarea视图中,last_load_time和last_active_time,解释如下,

LAST_LOAD_TIME,DATE类型
Time at which the query plan was loaded into the library cache

执行计划载入library cache库缓存的时间


LAST_ACTIVE_TIME,DATE类型
Time at which the query plan was last active

SQL最新一次执行的时间

在v$sql视图中,last_load_time和last_active_time,解释如下,

LAST_LOAD_TIME,VARCHAR2(19)类型
Time at which the query plan was loaded into the library cache

执行计划载入library cache库缓存的时间,但是他是VARCHAR2(19)类型


LAST_ACTIVE_TIME,DATE类型
TIme at which the query plan was last active

SQL最新一次执行的时间

执行新的SQL,这个SQL不在共享池中,这时会进行硬解析,v$sql中的last_active_time和last_load_time是硬解析的时间。

执行共享池内已经存在的SQL,会进行软解析,last_active_time是软解析的时间,也是SQL最新执行的时间,last_load_time的值不变。

因此,如果我的需求是找出前一天应用跑过的逻辑中使用全表扫描执行计划的SQL,从准确性讲,应该用的是last_active_time,不是last_load_time,因为很可能由于缓存了执行计划,last_load_time的值一直未变,此时last_active_time才会更可能满足到我们最初的需求。

近期热文:

truncate分区表的操作,会导致全局索引失效?

NUMBER长度的误解

《decode函数的妙用》网友的两个问题解答

decode函数的妙用

虚拟内存详解

7号球衣的故事:重要的不是号码,而是穿着它的人

插入"&"特殊字符的几种思考

connect by超乎你想象

公众号600篇文章分类和索引


转载:https://blog.csdn.net/bisal/article/details/105630136
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场