From: | Rafia Sabih <rafia(dot)pghackers(at)gmail(dot)com> |
---|---|
To: | Jonas Gassenmeyer <gassenmj(at)gmail(dot)com> |
Cc: | pgsql-novice(at)lists(dot)postgresql(dot)org |
Subject: | Re: Check explain plan of a running query in other session |
Date: | 2021-11-10 14:24:11 |
Message-ID: | CA+FpmFf16zXGvQB_MMVeh79Wm-gRE3AGLofVKo5qsJGzOaYOtA@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-novice |
On Mon, 8 Nov 2021 at 09:20, Jonas Gassenmeyer <gassenmj(at)gmail(dot)com> wrote:
>
> Hello,
>
> I am asking myself for a while if there is an easy option (via dictionary views like pg_stat_activity or similar) to check what execution plan was chosen for a long running SQL statement while it is running in a different session?
> I have a performance problem in a plpgsql procedure that executes an update within a loop. My guess is that it chose a generic plan instead of bind peeking and then does not use an index.
>
> I am not able to proof my theory, since I don't know how to get the explain plan for it.
> For me the easiest would be to check the running statement in a different session and "hook into" the other plpgsql session to check what the optimizer chose.
>
> Is that something I can do easily? If not: What is the PostgreSQL way of doing it?
It is for reasons like these that we at Zalando developed an extension
pg_mon (https://github.com/RafiaSabih/pg_mon)
There you can find details like what are the scan methods and joins
etc used by the query.
You can give this a try.
--
Regards,
Rafia Sabih
From | Date | Subject | |
---|---|---|---|
Next Message | Jean Baro | 2021-11-11 14:23:21 | Phonetic representation LENGHT for DMETAPHONE, is there a way to make it longer? |
Previous Message | Laurenz Albe | 2021-11-08 08:42:46 | Re: Check explain plan of a running query in other session |