如何在Oracle中识别等待次数最多的SQL查询?

问题:

您想要确定负责数据库中最长时间等待的SQL语句。

我们可以使用下面的SQL语句来识别导致问题的SQL。下面的查询将对过去30分钟内运行的SQL语句进行排名,并按照每个查询等待的总时间显示它们。

示例

SELECT ash.user_id,
  u.username,
  s.sql_text,
  SUM(ash.wait_time + ash.time_waited) ttl_wait_time
FROM v$active_session_history ash,
  v$sqlarea s,
  dba_users u
WHERE ash.sample_time BETWEEN sysdate - 60/2880 AND sysdate
AND ash.sql_id  = s.sql_id
AND ash.user_id = u.user_id
GROUP BY ash.user_id,
  s.sql_text,
  u.username
ORDER BY ttl_wait_time ;

如果遇到性能问题,建议验证等待最多的SQL语句。若要查找最等待的查询,必须对特定SQL语句的“ V $ACTIVE_SESSION_HISTORY”的wait_time和time_waited列中的值求和。为此,必须使用SQL_ID作为连接列,将V $SQLAREA视图与“ V $ACTIVE_SESSION_HISTORY”视图连接在一起。