diff options
author | Alexander Korotkov <akorotkov@postgresql.org> | 2024-11-24 01:41:45 +0200 |
---|---|---|
committer | Alexander Korotkov <akorotkov@postgresql.org> | 2024-11-24 01:41:45 +0200 |
commit | ae4569161a27823793ca24825bbabce2a91a0bc9 (patch) | |
tree | 59d2131807aed4b471ad48e0d7a0e55bfa213ff9 /src/include/postgres.h | |
parent | d4378c0005e61b1bb78e88097ea6efcdddbe2d6e (diff) | |
download | postgresql-ae4569161a27823793ca24825bbabce2a91a0bc9.tar.gz postgresql-ae4569161a27823793ca24825bbabce2a91a0bc9.zip |
Teach bitmap path generation about transforming OR-clauses to SAOP's
When optimizer generates bitmap paths, it considers breaking OR-clause
arguments one-by-one. But now, a group of similar OR-clauses can be
transformed into SAOP during index matching. So, bitmap paths should
keep up.
This commit teaches bitmap paths generation machinery to group similar
OR-clauses into dedicated RestrictInfos. Those RestrictInfos are considered
both to match index as a whole (as SAOP), or to match as a set of individual
OR-clause argument one-by-one (the old way).
Therefore, bitmap path generation will takes advantage of OR-clauses to SAOP's
transformation. The old way of handling them is also considered. So, there
shouldn't be planning regression.
Discussion: https://postgr.es/m/CAPpHfdu5iQOjF93vGbjidsQkhHvY2NSm29duENYH_cbhC6x%2BMg%40mail.gmail.com
Author: Alexander Korotkov, Andrey Lepikhov
Reviewed-by: Alena Rybakina, Andrei Lepikhov, Jian he, Robert Haas
Reviewed-by: Peter Geoghegan
Diffstat (limited to 'src/include/postgres.h')
0 files changed, 0 insertions, 0 deletions