作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的查询需要很长时间才能执行(不同的操作)。但该查询未在 v$session_longops 中列出。如何强制将查询放入 v$session_longops。
最佳答案
不幸的是,如果您正在谈论单个 SQL 查询,您可能无法强制它显示在 V$SESSION_LONGOPS
中。当一个步骤花费超过 6 秒时,Oracle 会将查询写入 V$SESSION_LONGOPS
。但是您可以有一个由许多非常短的步骤组成的运行时间非常长的查询。例如,内部查询和外部查询都使用索引来获取数据的嵌套循环连接可以运行很长时间,但单个操作可能需要不到一秒钟的时间。如果是这种情况,通常值得将优化器的估计基数与实际基数进行比较。 Oracle 很可能正在执行大量短操作,因为它低估了操作各个步骤的基数。对优化器进行更好的估计可能会产生更高效的查询计划,并在 V$SESSION_LONGOPS
中跟踪更长的操作。
如果您正在谈论恰好发出一个或多个 SQL 查询的 PL/SQL 流程,Rajesh 的评论是正确的。您可以使用 DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS method在 V$SESSION_LONGOPS
中跟踪 PL/SQL 流程的进度。
关于oracle - 强制查询 v$session_longops,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6497067/
我的查询需要很长时间才能执行(不同的操作)。但该查询未在 v$session_longops 中列出。如何强制将查询放入 v$session_longops。 最佳答案 不幸的是,如果您正在谈论单个
我是一名优秀的程序员,十分优秀!