在使用 ASH (Active Session History) 分析并发问题时,可以使用以下代码示例同时进行 IN_PARSE 和 IN_SQL_EXECUTION 的统计:
-- 创建一个辅助函数,用于获取 IN_PARSE 和 IN_SQL_EXECUTION 的统计信息
CREATE OR REPLACE FUNCTION ash_parse_execution_stats
RETURN SYS_REFCURSOR
IS
sql_id VARCHAR2(13);
cursor_name SYS_REFCURSOR;
BEGIN
-- 获取当前会话的 SQL_ID
SELECT sql_id INTO sql_id
FROM v$session
WHERE sid = sys_context('userenv', 'sid');
-- 获取 IN_PARSE 和 IN_SQL_EXECUTION 的统计信息
OPEN cursor_name FOR
SELECT sample_time, ash.SQL_ID, event, COUNT(*)
FROM v$active_session_history ash
WHERE ash.SQL_ID = sql_id
AND (event = 'SQL*Net message from client' OR event = 'SQL*Net message to client')
GROUP BY sample_time, ash.SQL_ID, event
ORDER BY sample_time;
-- 返回游标
RETURN cursor_name;
END;
/
使用上述辅助函数可以同时获取 IN_PARSE 和 IN_SQL_EXECUTION 的统计信息。可以通过以下代码示例调用该函数并显示结果:
-- 调用辅助函数并显示结果
VAR rc REFCURSOR;
EXEC :rc := ash_parse_execution_stats;
PRINT rc;
执行以上代码后,将会显示包含 IN_PARSE 和 IN_SQL_EXECUTION 统计信息的结果集。请注意,这里仅考虑了与网络通信相关的等待事件,如果还有其他等待事件需要考虑,可以根据具体情况进行调整。