Hi Alexander

From your EXPLAIN (ANALYZE, BUFFERS), execution is fast because the very first step is an index scan on _reference127 that returns 0 rows, so almost all subplans/EXISTS parts are “never executed”. The ~450 ms is therefore almost entirely /planning/work, not query runtime.

The key clue is “Planning Buffers: shared hit=2717”, which means the planner is doing lots of catalog/statistics/path exploration in memory (CPU cost), not waiting on disk. Two likely multipliers in your setup are (1) join_collapse_limit/from_collapse_limit = 20 (larger join search/flattening space), and (2) plantuner in shared_preload_libraries (planner hook overhead). Quick checks: in-session set join_collapse_limit=1 and from_collapse_limit=1 and compare Planning Time; then (restart required) temporarily remove plantuner from shared_preload_libraries and retest. These A/B tests usually identify whether the overhead is join-search settings or extension hook cost.

Best regards,
[Your Name]


在 2026/1/13 17:16, Alexander Kulikov 写道:
Hello!


I have got huge planning time for a query in quite small database in PortgreSQL 17
 Planning Time: 452.796 ms
 Execution Time: 0.350 ms

Tried several version from 17.3 to 17.7 (cpu 2.2GHz) - it almost does not matter. If I run query many times in row planning time may reduce down to 430ms but never less.

Tried in PortgreSQL 11 (in a little bit different hardware with cpu 2.60GHz) - planning time almost ten times less.

Changing parameters: from_collapse_limit, join_collapse_limit, geqo, jit, work_mem and many others does not help at all. I attach 1. additional setting in the postgresql.status.conf. 2. querry itself in query.sql. 3. zql plan in query.sqlplan 4. additioanal information about os, tables etc. would you please help me -Alexander Kulikov





Reply via email to