如何在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 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短