On 24 Feb 2026, at 20:20, Andrei Lepikhov <[email protected]> wrote:
> 
> On 24/2/26 17:48, Attila Soki wrote:
>>> On 24 Feb 2026, at 16:57, Andrei Lepikhov <[email protected]> wrote:
>>> On 24/2/26 16:50, Attila Soki wrote:
>> I can provide more details on other parts of the query too, if that helps.
> 
> Only query and reproduction make sense for me to discover more deeply at
> the moment.
> It looks like we have managed to reproduce the potential 'Hash over
> parameterised subtree' issue. Please check the attachment: there are two
> plans. One plan has a longer execution time and more blocks hit, but its
> cost estimate is four times lower. The EXPLAIN output does not show any
> obvious estimation errors. This suggests there may be a bug in the cost
> model.
> 

I looked your repro, and I tried to find the corresponding part in my query.
If that not the right place is, please point me to the part in explain, so I 
can compare your repro and that part of my query.

As far as I can identify, there are two candidates:
The first one because of "lateral", but I think this is not the problematic part
        select
        from
        left join lateral ()

        somewhere around this line:
        Output: dim_kal.oo_id, dim_stamm.dmn_gew, dim_kal.art_vk, 
dim_stamm.dmn_anz, dim_kal.art_bl, dim_kal.art_dp, dim_stamm.dmn_vol, 
dim_ext_dd.table_d_id, dim_ext_dd_dpe.enabled, dim_kal.rti_id, 
dim_stamm.ist_divers_rti, dim_stamm.ist_psa_rti


The second one because of your prior comment about "odg" and "rebuilt multiple 
times (around 1k) due to an external parameter (gauf_1.id)"
        gauf_1 refers to a view and this view is used multiple times in the 
query. see my previous mail for more details about gauf_1.

        select
        ...
        from (
                with (
                        select
                        ...
                        from table_k kal
                        where ...
                                AND not ( exists (
                                        select oo_id from "view_gauf_1" gdt_2
                                        where gdt_2.rti_id = kal.rti_id ... AND 
gdt_2.datum >= ('now'::cstring)::date) .. and gauf_2....
                                ))
                ) spaet
                select
                ...
                from view
                left join spaet on spaet.rti_id::text = akd.dp_rti_id::text
                left join lateral ( select from where )
                left join lateral ( select from where )
                ...
                
                somewhere around this line:
                "Filter: ((ext_dd.table_d_id IS NULL) OR 
((ext_dd.table_d_id)::text = 'schema1'::text) OR (NOT 
COALESCE(ext_dd_dpe.enabled, false)))"

        ) table_k_dly
        

Thank you.

Regards,
Attila



Reply via email to