如何在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 婆婆高寿祝福语大全简短