Re: [PATCH] Optionally record Plan IDs to track plan changes for a query
| От | Julien Rouhaud | 
|---|---|
| Тема | Re: [PATCH] Optionally record Plan IDs to track plan changes for a query | 
| Дата | |
| Msg-id | Z6wF_eCtCjav3hrQ@jrouhaud обсуждение исходный текст | 
| Ответ на | Re: [PATCH] Optionally record Plan IDs to track plan changes for a query (Sami Imseih <samimseih@gmail.com>) | 
| Ответы | Re: [PATCH] Optionally record Plan IDs to track plan changes for a query | 
| Список | pgsql-hackers | 
On Wed, Feb 12, 2025 at 10:59:04AM +0900, Michael Paquier wrote: > On Wed, Feb 12, 2025 at 09:20:53AM +0800, Julien Rouhaud wrote: > > > > FTR my main motivation was to be able to deal with queries referencing > > temporary relations, as if your application creates a lot of those it basically > > means that you cannot use pg_stat_statements anymore. > > Do you have an issue more details about your problem? If we can > improve the situation in core without impacting the existing cases > that we need to support in pgss, that may be worth looking at. I thought this was a well known limitation. The basic is that if you rely on temp tables, you usually end up with a virtually infinite number of queryids since all temp tables get a different oid and that oid is used in the queryid computation. And in that case the overhead of pg_stat_statements is insanely high. The last figures I saw was by Andres many years ago, with a mention 40% overhead, and I don't think it's hard to get way worse overhead than that if you have lengthier query texts. As a prototype in my extension I think I just entirely ignored such queries, but another (and probably friendlier for the actual pg_stat_statements statistics) approach would be to use the relation name to compute the queryid rather than its oid. This would add some overhead, but I think it would have very limited impact especially compared to the current situation. Of course some people may want to keep the current behavior, if they have limited number of temp tables or similar, so I had a GUC for that. I don't think that the community would really welcome such GUC for core-postgres, especially since it wouldn't be pg_stat_statements specific.
В списке pgsql-hackers по дате отправления: