From: | Matthias van de Meent <boekewurm+postgres(at)gmail(dot)com> |
---|---|
To: | Peter Geoghegan <pg(at)bowt(dot)ie> |
Cc: | PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org> |
Subject: | Re: More reliable nbtree detection of unsatisfiable RowCompare quals involving a leading NULL key/element |
Date: | 2025-01-07 12:57:59 |
Message-ID: | CAEze2Wg0TT_7Vi78yYC1bE47gx0MacU4EScgyNAZxo+BZrxU8A@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On Fri, 27 Dec 2024 at 23:03, Peter Geoghegan <pg(at)bowt(dot)ie> wrote:
>
> On Mon, Dec 23, 2024 at 1:02 PM Peter Geoghegan <pg(at)bowt(dot)ie> wrote:
> > Attached patch fixes the problem by moving detection of RowCompare
> > unsatisfiable-due-to-NULL cases into _bt_fix_scankey_strategy.
>
> Attached is v2, which adds several new regression tests, giving
> certain relevant nbtree code paths test coverage.
>
> v2 also makes some small tweaks to _bt_check_rowcompare(), the actual
> comparator used by scans with a RowCompare qual. We no longer need to
> account for the possibility that the first row member from a
> RowCompare scan key contains a null once the scan is underway (we know
> that _bt_preprocess_keys would have recognized the qual as
> unsatisfiable had the RowCompare looked like that).
backend/access/nbtree/nbtsearch.c:_bt_first
> + * Cannot be a NULL in the first row member (that would make the
> + * qual unsatisfiable, preventing it from ever getting this far)
This doesn't really clarify _why_ we'd never get this far, so I'd word that as
+ * Cannot be a NULL in the first row member: _bt_preprocess_keys
+ * would've marked the qual as unsatisfyable, preventing us from
+ * ever getting this far.
Apart from that minor issue, LGTM.
Kind regards,
Matthias van de Meent
From | Date | Subject | |
---|---|---|---|
Next Message | Yura Sokolov | 2025-01-07 13:40:41 | Re: Meson bug in detection of 64 atomics |
Previous Message | Zhijie Hou (Fujitsu) | 2025-01-07 12:49:55 | RE: Conflict detection for update_deleted in logical replication |