CYBERTEC PostgreSQL Logo

pg_stat_statements: The way I like it

10.2015 / Category: / Tags: |

If you really want to track down slow queries, massive I/O and lousy performance, there is no way around the pg_stat_statements extension.

However, the pg_stat_statements system view is full of information and many people get lost. Therefore it can make sense, to come up with a clever query to provide administrators with really relevant information. Without finding the really relevant information, tuning is somewhat pointless.

Here is my personal favorite query to track down slow queries:

The output contains a short version of the query (this can be handy if you are using text terminal as I do). Then there is the tota_execl_time of the query in the first column along with the number of calls and the mean execution time.

Personally I have found it useful to calculate an overall percentage for each query. It helps me to get a feeling of what lies in stock for me in case I can manage to optimize a certain query. To me the percentage value provides me with relevance because it is pretty pointless to work on queries, which only need 0.5% of time:

Working top down is usually a good idea.

Of course everybody will have his own ideas of how to approach the problem and the information provided by the query is not sufficient to fully optimize a system. However, I have found it useful to gain a quick overview of what is going on.

See also my blog about speeding up slow queries.

9 responses to “pg_stat_statements: The way I like it”

  1. In Azure Postgres SQL, I get for the short_query field on most of the rows, except for a few python scripts I used to create the tables. Any tips on seeing the queries?

  2. query should be updated, because there is no total_time or mean_time instead there is total_exec_time and mean_exec_time

  3. please find the updated query for postgres-14

    select substring(query,1, 50) AS short_query,
    round(total_exec_time::numeric, 2) AS total_exec_time,
    calls,round(min_exec_time::numeric,2) AS mean,
    round((100*total_exec_time/ sum(total_exec_time::numeric)
    OVER())::numeric,2) AS percentage_overall

    from pg_stat_statements
    order by total_exec_time desc
    LIMIT 20;

Leave a Reply

Your email address will not be published. Required fields are marked *

CYBERTEC Logo white
Get the newest PostgreSQL Info & Tools


    This site is protected by reCAPTCHA and the Google Privacy Policy & Terms of Service apply.

    ©
    2025
    CYBERTEC PostgreSQL International GmbH
    phone-handsetmagnifiercrosscross-circle
    linkedin facebook pinterest youtube rss twitter instagram facebook-blank rss-blank linkedin-blank pinterest youtube twitter instagram