如何在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”视图连接在一起。
热门推荐
10 5岁宝宝祝福语简短
11 周末祝福语简短的英语
12 生日祝福语大全女孩简短
13 Q穷人结婚祝福语简短
14 领证幽默祝福语简短
15 简短的出行工作祝福语
16 姐姐女儿结婚祝福语简短
17 婆婆生日祝福语短语简短
18 简短祝福语大全暖心