我的查询需要花费很多时间才能执行(不同的操作)。但该查询未在v $ session_longops中列出。如何强制将查询放入v $ session_longops。
答案 0 :(得分:4)
不幸的是,如果您正在讨论单个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流程的进度。