last_load_time和last_active_time的选择

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

SELECT s.sql_text, P.OBJECT_OWNER,
       P.SQL_ID,
       P.OPERATION,
       P.OPTIONS,
       S.LAST_LOAD_TIME,
       ROW_NUMBER() OVER(PARTITION BY P.SQL_ID ORDER BY P.SQL_ID) AS ROWNUMS
       FROM V$SQL_PLAN P, V$SQLAREA S
 WHERE S.SQL_ID = P.SQL_ID
   AND P.OPERATION = 'TABLE ACCESS'
   AND P.OPTIONS = 'FULL'
   AND S.LAST_LOAD_TIME >= trunc(SYSDATE-1)
 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篇文章分类和索引

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个错误通常是因为您在字符串上尝试使用 `last_cell` 属性。但是,`last_cell` 属性是一个工作表对象的属性,而不是一个字符串对象的属性。 我猜测您可能是从 Excel 文件中读取了一个单元格并将其存储在了一个字符串变量中。如果您想要获取该单元格所在行的行号,可以使用 `openpyxl.utils.cell.column_index_from_string()` 函数来获取单元格列的索引,然后使用 `openpyxl.worksheet.worksheet.Worksheet.cell()` 方法来获取该单元格所在的行对象,最后使用 `row` 属性来获取该行号。示例如下: ``` from openpyxl import load_workbook from openpyxl.utils import cell # 加载工作簿 workbook = load_workbook(filename='example.xlsx') # 获取活动工作表 worksheet = workbook.active # 读取单元格 A1 的值 cell_value = worksheet['A1'].value # 获取单元格所在列的索引 column_index = cell.column_index_from_string('A') # 获取单元格所在行的行对象 row = worksheet.cell(row=1, column=column_index).row # 输出行号 print(row) ``` 这将输出 1,即单元格 A1 所在的行号。如果您需要处理多个单元格,可以使用循环来处理每个单元格。 ### 回答2: 这个错误是因为在某个字符串对象上使用了"last_cell"属性,但是这个属性在字符串对象中是不存在的。根据错误信息可以猜测,这个错误是在处理"info"这个变量的时候发生的。 根据错误信息,"rows = info.last_cell.row"这一行出现问题。由于"info"是一个字符串对象,我们不能在字符串上使用"last_cell"属性。为了解决这个错误,需要确认一下"info"变量的值是什么类型的。 如果"info"是一个字符串变量,并且我们需要获取这个字符串的最后一个单元格的行号,我们可以考虑使用其他的方法来实现。比如,可以将字符串转换成一个Excel表格对象,然后使用特定的方法来获取最后一个单元格的行号。 另外,我们也需要确认一下是否有其他的变量或者对象名字叫做"info",并且它是一个Excel表格对象。如果是的话,可能是因为其他地方对这个对象进行了修改,导致了属性错误的问题。解决这个问题可能需要仔细检查代码逻辑和确认对象的类型和属性。 总之,要解决这个错误,可以通过检查"info"变量的类型和属性,或者修改代码逻辑来修复问题。 ### 回答3: 这个错误是由于属性错误引发的。info是一个字符串对象,而字符串对象没有名为last_cell的属性,因此无法使用该属性。要解决这个问题,可以检查代码中对info的使用,确保其类型是一个表格或工作簿对象,并且具有last_cell属性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值