暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

GaussDB查询最耗性能的SQL

li 2023-06-28
102

系统中有些SQL语句运行了很长时间还没有结束,这些语句会消耗很多的系统性能,请根据本章内容查询长时间运行的SQL语句。

操作步骤

  1. 使用DAS或者gsql连接实例。
  2. 查询系统中长时间运行的查询语句。


    SELECT current_timestamp - query_start AS runtime, datname, usename, query FROM pg_stat_activity where state != 'idle' ORDER BY 1 desc;


    查询后会按执行时间从长到短顺序返回查询语句列表,第一条结果就是当前系统中执行时间最长的查询语句。返回结果中包含了系统调用的SQL语句和用户执行SQL语句,请根据实际找到用户执行时间长的语句。

    若当前系统较为繁忙,可以通过限制current_timestamp - query_start大于某一阈值来查看执行时间超过此阈值的查询语句。

    SELECT query FROM pg_stat_activity WHERE current_timestamp - query_start > interval '1 days';



  3. 设置参数track_activities为on。


    SET track_activities = on;


    当此参数为on时,数据库系统才会收集当前活动查询的运行信息。


  4. 查看正在运行的查询语句。


    以查看视图pg_stat_activity为例:

    SELECT datname, usename, state FROM pg_stat_activity; 
     datname  | usename | state  | 
    ----------+---------+--------+ 
     postgres |   omm   | idle   | 
     postgres |   omm   | active | 
    (2 rows)


    如果state字段显示为idle,则表明此连接处于空闲,等待用户输入命令。

    如果仅需要查看非空闲的查询语句,则使用如下命令查看:

    SELECT datname, usename, state FROM pg_stat_activity WHERE state != 'idle';



  5. 分析长时间运行的查询语句状态。


    • 若查询语句处于正常状态,则等待其执行完毕。
    • 若查询语句阻塞,则通过如下命令查看当前处于阻塞状态的查询语句:
      SELECT datname, usename, state, query FROM pg_stat_activity WHERE waiting = true;


      查询结果中包含了当前被阻塞的查询语句,该查询语句所请求的锁资源可能被其他会话持有,正在等待持有会话释放锁资源。

    只有当查询阻塞在系统内部锁资源时,waiting字段才显示为true。尽管等待锁资源是数据库系统最常见的阻塞行为,但是在某些场景下查询也会阻塞在等待其他系统资源上,例如写文件、定时器等。但是这种情况的查询阻塞,不会在视图pg_stat_activity中体现。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论